{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "from torchvision import datasets\n",
    "import numpy as np\n",
    "import torch\n",
    "import matplotlib.pyplot as plt\n",
    "from torchvision import transforms\n",
    "from torch.utils.data import DataLoader\n",
    "from tqdm import tqdm\n",
    "from torch.utils.tensorboard import SummaryWriter\n",
    "from datetime import datetime\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.optim as optim\n",
    "from vit_pytorch import ViT  # ViT model\n",
    "import os\n",
    "from torchmetrics import Accuracy\n",
    "from pathlib import Path\n",
    "from captum.attr import IntegratedGradients, GradientShap, DeepLift\n",
    "from utils import *\n",
    "device = 'cuda' if torch.cuda.is_available() else 'cpu'"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Dataloader"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Downloading http://yann.lecun.com/exdb/mnist/train-images-idx3-ubyte.gz\n",
      "Failed to download (trying next):\n",
      "HTTP Error 403: Forbidden\n",
      "\n",
      "Downloading https://ossci-datasets.s3.amazonaws.com/mnist/train-images-idx3-ubyte.gz\n",
      "Downloading https://ossci-datasets.s3.amazonaws.com/mnist/train-images-idx3-ubyte.gz to ./datasets/MNIST/raw/train-images-idx3-ubyte.gz\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 9.91M/9.91M [00:01<00:00, 7.46MB/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Extracting ./datasets/MNIST/raw/train-images-idx3-ubyte.gz to ./datasets/MNIST/raw\n",
      "\n",
      "Downloading http://yann.lecun.com/exdb/mnist/train-labels-idx1-ubyte.gz\n",
      "Failed to download (trying next):\n",
      "HTTP Error 403: Forbidden\n",
      "\n",
      "Downloading https://ossci-datasets.s3.amazonaws.com/mnist/train-labels-idx1-ubyte.gz\n",
      "Downloading https://ossci-datasets.s3.amazonaws.com/mnist/train-labels-idx1-ubyte.gz to ./datasets/MNIST/raw/train-labels-idx1-ubyte.gz\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 28.9k/28.9k [00:00<00:00, 251kB/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Extracting ./datasets/MNIST/raw/train-labels-idx1-ubyte.gz to ./datasets/MNIST/raw\n",
      "\n",
      "Downloading http://yann.lecun.com/exdb/mnist/t10k-images-idx3-ubyte.gz\n",
      "Failed to download (trying next):\n",
      "HTTP Error 403: Forbidden\n",
      "\n",
      "Downloading https://ossci-datasets.s3.amazonaws.com/mnist/t10k-images-idx3-ubyte.gz\n",
      "Downloading https://ossci-datasets.s3.amazonaws.com/mnist/t10k-images-idx3-ubyte.gz to ./datasets/MNIST/raw/t10k-images-idx3-ubyte.gz\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1.65M/1.65M [00:00<00:00, 2.48MB/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Extracting ./datasets/MNIST/raw/t10k-images-idx3-ubyte.gz to ./datasets/MNIST/raw\n",
      "\n",
      "Downloading http://yann.lecun.com/exdb/mnist/t10k-labels-idx1-ubyte.gz\n",
      "Failed to download (trying next):\n",
      "HTTP Error 403: Forbidden\n",
      "\n",
      "Downloading https://ossci-datasets.s3.amazonaws.com/mnist/t10k-labels-idx1-ubyte.gz\n",
      "Downloading https://ossci-datasets.s3.amazonaws.com/mnist/t10k-labels-idx1-ubyte.gz to ./datasets/MNIST/raw/t10k-labels-idx1-ubyte.gz\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 4.54k/4.54k [00:00<00:00, 14.9MB/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Extracting ./datasets/MNIST/raw/t10k-labels-idx1-ubyte.gz to ./datasets/MNIST/raw\n",
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "(1688, 188, 313)"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "BATCH_SIZE = 32\n",
    "mnist_transforms = transforms.Compose([transforms.ToTensor()])\n",
    "train_val_dataset = datasets.MNIST(root=\"./datasets/\", train=True, download=True, transform=mnist_transforms)\n",
    "test_dataset = datasets.MNIST(root=\"./datasets/\", train=False, download=True, transform=mnist_transforms)\n",
    "train_val_dataset, test_dataset\n",
    "train_size = int(0.9 * len(train_val_dataset))\n",
    "val_size = len(train_val_dataset) - train_size\n",
    "train_dataset, val_dataset = torch.utils.data.random_split(dataset=train_val_dataset, lengths=[train_size, val_size])\n",
    "len(train_dataset), len(val_dataset), len(test_dataset)\n",
    "\n",
    "train_dataloader = DataLoader(dataset=train_dataset, batch_size=BATCH_SIZE, shuffle=True)\n",
    "val_dataloader = DataLoader(dataset=val_dataset, batch_size=BATCH_SIZE, shuffle=True)\n",
    "test_dataloader = DataLoader(dataset=test_dataset, batch_size=BATCH_SIZE, shuffle=True)\n",
    "len(train_dataloader), len(val_dataloader), len(test_dataloader) "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### First ViT Model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  7%|▋         | 1/15 [00:24<05:36, 24.06s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 1 | Train Loss: 0.67245 | Train Accuracy: 0.79541 | Val Loss: 0.18838 | Val Accuracy: 0.94614\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 13%|█▎        | 2/15 [00:47<05:09, 23.81s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 2 | Train Loss: 0.20723 | Train Accuracy: 0.93926 | Val Loss: 0.12411 | Val Accuracy: 0.96326\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 20%|██        | 3/15 [01:10<04:37, 23.13s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 3 | Train Loss: 0.15586 | Train Accuracy: 0.95292 | Val Loss: 0.10359 | Val Accuracy: 0.96908\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 27%|██▋       | 4/15 [01:32<04:10, 22.80s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 4 | Train Loss: 0.12426 | Train Accuracy: 0.96233 | Val Loss: 0.08871 | Val Accuracy: 0.97307\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 33%|███▎      | 5/15 [01:54<03:47, 22.73s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 5 | Train Loss: 0.10835 | Train Accuracy: 0.96645 | Val Loss: 0.07891 | Val Accuracy: 0.97606\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 40%|████      | 6/15 [02:18<03:27, 23.00s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 6 | Train Loss: 0.09641 | Train Accuracy: 0.96990 | Val Loss: 0.07987 | Val Accuracy: 0.97523\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 47%|████▋     | 7/15 [02:37<02:54, 21.80s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 7 | Train Loss: 0.08529 | Train Accuracy: 0.97340 | Val Loss: 0.07453 | Val Accuracy: 0.97689\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 53%|█████▎    | 8/15 [02:57<02:27, 21.06s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 8 | Train Loss: 0.07556 | Train Accuracy: 0.97645 | Val Loss: 0.06897 | Val Accuracy: 0.97939\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 60%|██████    | 9/15 [03:19<02:09, 21.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 9 | Train Loss: 0.07052 | Train Accuracy: 0.97795 | Val Loss: 0.06834 | Val Accuracy: 0.97939\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 67%|██████▋   | 10/15 [03:39<01:44, 20.96s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 10 | Train Loss: 0.06371 | Train Accuracy: 0.98002 | Val Loss: 0.06547 | Val Accuracy: 0.98072\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 73%|███████▎  | 11/15 [03:59<01:23, 20.79s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 11 | Train Loss: 0.05945 | Train Accuracy: 0.98104 | Val Loss: 0.06326 | Val Accuracy: 0.98155\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 80%|████████  | 12/15 [04:22<01:04, 21.42s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 12 | Train Loss: 0.05435 | Train Accuracy: 0.98258 | Val Loss: 0.06141 | Val Accuracy: 0.98105\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 87%|████████▋ | 13/15 [04:45<00:43, 21.80s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 13 | Train Loss: 0.04922 | Train Accuracy: 0.98449 | Val Loss: 0.06474 | Val Accuracy: 0.98172\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 93%|█████████▎| 14/15 [05:07<00:21, 21.77s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 14 | Train Loss: 0.04630 | Train Accuracy: 0.98515 | Val Loss: 0.06162 | Val Accuracy: 0.98305\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 15/15 [05:30<00:00, 22.00s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 15 | Train Loss: 0.04370 | Train Accuracy: 0.98554 | Val Loss: 0.06028 | Val Accuracy: 0.98105\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "# Experiment tracking setup\n",
    "timestamp = datetime.now().strftime(\"%Y-%m-%d\")\n",
    "experiment_name = \"MNIST\"\n",
    "model_name = \"VisionTransformer_v1\"\n",
    "log_dir = os.path.join(\"runs\", timestamp, experiment_name, model_name)\n",
    "writer = SummaryWriter(log_dir)\n",
    "\n",
    "# Device setup\n",
    "device = 'cuda' if torch.cuda.is_available() else 'cpu'\n",
    "\n",
    "model_vit = ViT(\n",
    "    image_size=28,       # MNIST images are 28x28\n",
    "    patch_size=4,        # 4 patches per dimension (28/7)\n",
    "    num_classes=10,      # 10 output classes for digits 0-9\n",
    "    dim=64,             # Embedding dimension\n",
    "    depth=6,             # Number of transformer layers\n",
    "    heads=8,             # Number of attention heads\n",
    "    mlp_dim=128,         # Hidden dimension in MLP layers\n",
    "    dropout=0.1,         # Dropout rate in transformer\n",
    "    emb_dropout=0.1,     # Dropout rate for embeddings\n",
    "    channels = 1\n",
    ").to(device)\n",
    "\n",
    "loss_fn = nn.CrossEntropyLoss()\n",
    "optimizer = optim.Adam(model_vit.parameters(), lr=1e-4)\n",
    "\n",
    "\n",
    "\n",
    "accuracy = Accuracy(task='multiclass', num_classes=10).to(device)\n",
    "# Training and Validation Loops\n",
    "EPOCHS = 15\n",
    "for epoch in tqdm(range(EPOCHS)):\n",
    "    # Training Loop\n",
    "    train_loss, train_acc = 0.0, 0.0\n",
    "    model_vit.train()\n",
    "    torch.manual_seed(epoch)\n",
    "    for X, y in train_dataloader:\n",
    "        X, y = X.to(device), y.to(device)\n",
    "       # print(X.shape)\n",
    "        optimizer.zero_grad()\n",
    "        \n",
    "        # Forward pass\n",
    "        y_pred = model_vit(X)\n",
    "        loss = loss_fn(y_pred, y)\n",
    "        train_loss += loss.item()\n",
    "        train_acc += accuracy(y_pred, y)\n",
    "        \n",
    "        # Backward pass and optimization\n",
    "        loss.backward()\n",
    "        optimizer.step()\n",
    "\n",
    "    # Average metrics\n",
    "    train_loss /= len(train_dataloader)\n",
    "    train_acc /= len(train_dataloader)\n",
    "\n",
    "    # Validation Loop\n",
    "    val_loss, val_acc = 0.0, 0.0\n",
    "    model_vit.eval()\n",
    "    torch.manual_seed(epoch)\n",
    "    with torch.no_grad():\n",
    "        for X, y in val_dataloader:\n",
    "            X, y = X.to(device), y.to(device)\n",
    "            \n",
    "            # Forward pass\n",
    "            y_pred = model_vit(X)\n",
    "            loss = loss_fn(y_pred, y)\n",
    "            val_loss += loss.item()\n",
    "            val_acc += accuracy(y_pred, y)\n",
    "\n",
    "    # Average metrics\n",
    "    val_loss /= len(val_dataloader)\n",
    "    val_acc /= len(val_dataloader)\n",
    "\n",
    "    # Log metrics to TensorBoard\n",
    "    writer.add_scalars(main_tag=\"Loss\", tag_scalar_dict={\"train/loss\": train_loss, \"val/loss\": val_loss}, global_step=epoch)\n",
    "    writer.add_scalars(main_tag=\"Accuracy\", tag_scalar_dict={\"train/acc\": train_acc, \"val/acc\": val_acc}, global_step=epoch)\n",
    "\n",
    "    # Print progress\n",
    "    print(f\"Epoch: {epoch+1} | Train Loss: {train_loss:.5f} | Train Accuracy: {train_acc:.5f} | Val Loss: {val_loss:.5f} | Val Accuracy: {val_acc:.5f}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "MODEL_PATH = Path(\"models\")\n",
    "MODEL_PATH.mkdir(parents=True, exist_ok=True)\n",
    "MODEL_NAME = \"ViT_v1_mnist.pth\"\n",
    "MODEL_SAVE_PATH = MODEL_PATH / MODEL_NAME\n",
    "#Saving the model\n",
    "#print(f\"Saving the model: {MODEL_SAVE_PATH}\")\n",
    "#torch.save(obj=model_vit.state_dict(), f=MODEL_SAVE_PATH)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "#Loading the saved model\n",
    "model_ViT_mnist_loaded = ViT(\n",
    "    image_size=28,       # MNIST images are 28x28\n",
    "    patch_size=4,        # 4 patches per dimension (28/7)\n",
    "    num_classes=10,      # 10 output classes for digits 0-9\n",
    "    dim=64,             # Embedding dimension\n",
    "    depth=6,             # Number of transformer layers\n",
    "    heads=8,             # Number of attention heads\n",
    "    mlp_dim=128,         # Hidden dimension in MLP layers\n",
    "    dropout=0.1,         # Dropout rate in transformer\n",
    "    emb_dropout=0.1,     # Dropout rate for embeddings\n",
    "    channels = 1\n",
    ").to(device)\n",
    "\n",
    "model_ViT_mnist_loaded.load_state_dict(torch.load(MODEL_SAVE_PATH))\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Feature Attributions for first ViT model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "model_loaded = model_ViT_mnist_loaded.to(device)\n",
    "\n",
    "ig = IntegratedGradients(model_loaded)\n",
    "gs = GradientShap(model_loaded)\n",
    "dl = DeepLift(model_loaded)\n",
    "\n",
    "all_attributions_ig = []\n",
    "all_labels = []\n",
    "all_attributions_gs = []\n",
    "all_attributions_ks = []\n",
    "all_attributions_dl = []\n",
    "all_batches= []\n",
    "model_loaded.eval()\n",
    "torch.manual_seed(210)\n",
    "for batch_samples, batch_labels in tqdm(test_dataloader):\n",
    "    # Ensure samples have the correct shape\n",
    "    batch_labels = batch_labels.to(device)\n",
    "    batch_samples = batch_samples.requires_grad_().to(device) # Enable gradients for attribution\n",
    "    baseline_dist = torch.zeros((batch_samples.shape[0],1,28,28)).to(device)\n",
    "    \n",
    "\n",
    "    # Calculate the attributions for each sample in the batch\n",
    "    attributions, deltas = ig.attribute(batch_samples, target=batch_labels, return_convergence_delta=True)\n",
    "\n",
    "    \n",
    "    # Append attributions and labels for further analysis\n",
    "\n",
    "    all_attributions_ig.append(attributions)\n",
    "    all_labels.append(batch_labels)\n",
    "    all_batches.append(batch_samples.detach())\n",
    "    attributions_gs, deltas = gs.attribute(batch_samples, target=batch_labels,  baselines=baseline_dist,return_convergence_delta=True)\n",
    "    all_attributions_gs.append(attributions_gs)\n",
    "    \n",
    "\n",
    "    attributions_dl = dl.attribute(batch_samples, target=batch_labels)\n",
    "    all_attributions_dl.append(attributions_dl)\n",
    "\n",
    "\n",
    "# Concatenate all attributions and labels\n",
    "all_attributions_ig = torch.cat(all_attributions_ig, dim=0)  \n",
    "all_labels = torch.cat(all_labels, dim=0)\n",
    "\n",
    "all_attributions_gs = torch.cat(all_attributions_gs, dim=0)\n",
    "all_attributions_dl = torch.cat(all_attributions_dl, dim=0)\n",
    "\n",
    "all_batches = torch.cat(all_batches,dim=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "def filter_explanations(C1,C2,all_attributions_ig,all_attributions_dl,all_attributions_gs,all_labels):\n",
    "    data={'X':[],'Y':[],'Features':[],'IG':[],'GS':[],'DL':[]}\n",
    "    for c1,c2 in zip(C1,C2):\n",
    "        data['IG'].append(torch.abs(all_attributions_ig[all_labels ==c1 ].mean(axis=0)-all_attributions_ig[all_labels ==c2 ].mean(axis=0)).cpu().detach().numpy())\n",
    "        data['DL'].append(torch.abs(all_attributions_dl[all_labels ==c1 ].mean(axis=0)-all_attributions_dl[all_labels ==c2 ].mean(axis=0)).cpu().detach().numpy())\n",
    "        data['GS'].append(torch.abs(all_attributions_gs[all_labels ==c1 ].mean(axis=0)-all_attributions_gs[all_labels ==c2 ].mean(axis=0)).cpu().detach().numpy())\n",
    "\n",
    "        data_X = all_batches[all_labels==c1].mean(axis=0)[0,:,:]\n",
    "        data_Y = all_batches[all_labels==c2].mean(axis=0)[0,:,:]\n",
    "\n",
    "        data['X'].append(data_X)\n",
    "        data['Y'].append(data_Y)\n",
    "\n",
    "        rf, _, _ = remove_important_features(data_X.cpu().detach().numpy().reshape(1,784),data_Y.cpu().detach().numpy().reshape(1,784),250,1000)\n",
    "\n",
    "        Features = np.zeros(784)\n",
    "        f_id = []\n",
    "        contributions = []\n",
    "        k=1\n",
    "        for d in rf:\n",
    "            i = d[\"removed_feature\"]\n",
    "            Features[i] = 1/(np.log(k+1)**3)\n",
    "            k+=0.075\n",
    "            f_id.append(i)\n",
    "            contributions.append(d['contribution_value'])\n",
    "        data['Features'].append(Features)\n",
    "\n",
    "    return data\n",
    "\n",
    "\n",
    "def plot_MNIST_explanations(n_rows,n_cols,data):\n",
    "    fig, ax = plt.subplots(n_rows,n_cols,figsize=(12,6))\n",
    "    \n",
    "    for i in range(n_rows):\n",
    "        data_X = data['X'][i]\n",
    "        data_Y = data['Y'][i]\n",
    "        Features = data['Features'][i]\n",
    "        ig_plot = data['IG'][i]\n",
    "        gs_plot = data['GS'][i]\n",
    "        dl_plot = data['DL'][i]\n",
    "        ###first row set titles\n",
    "        if i==0:\n",
    "            ax[i,0].set_title('Before Drift',fontsize=17)\n",
    "            ax[i,1].set_title('After Drift',fontsize=17)\n",
    "            ax[i,2].set_title('SWD',fontsize=17)\n",
    "            ax[i,3].set_title('IG',fontsize=17)\n",
    "            ax[i,4].set_title('Grad SHAP',fontsize=17)\n",
    "            ax[i,5].set_title('DeepLift',fontsize=17)\n",
    "\n",
    "        ax[i,0].imshow(data_X.cpu().numpy(),cmap='gray')\n",
    "        ax[i,0].set_xticks([])\n",
    "        ax[i,0].set_yticks([])\n",
    "        ax[i,1].imshow(data_Y.cpu().numpy(),cmap='gray')\n",
    "        ax[i,1].set_xticks([])\n",
    "        ax[i,1].set_yticks([])\n",
    "        ax[i,2].imshow(np.float64(Features.reshape(28,28)),cmap='plasma')\n",
    "        ax[i,2].set_xticks([])\n",
    "        ax[i,2].set_yticks([])\n",
    "        ax[i,3].imshow(ig_plot[0,:,:],cmap='plasma')\n",
    "        ax[i,3].set_xticks([])\n",
    "        ax[i,3].set_yticks([])\n",
    "        ax[i,4].imshow(gs_plot[0,:,:], cmap='plasma')\n",
    "        ax[i,4].set_xticks([])\n",
    "        ax[i,4].set_yticks([])\n",
    "        ax[i,5].imshow(dl_plot[0,:,:], cmap='plasma')\n",
    "        ax[i,5].set_xticks([])\n",
    "        ax[i,5].set_yticks([])\n",
    "    \n",
    "\n",
    "    fig.tight_layout()\n",
    "\n",
    "    return fig"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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Y+eee+5eXNOxsXTp0mH7j97eXnvsscfsE5/4hBUXF9vjjz9uRx999B7dyfGOd7zDli1bZj/96U93eWxwf/L617/eFixYMOo2MDkNDAzY29/+dlu/fr3NmDHDbrjhBmttbbX29nbr6OiwrVu32i233GJve9vbLJFIDL3u1FNPNTOzv/zlL+5yn3rqKevu7h6681A9b7CeTqft2GOPdZ+zN8YIsLfccccd9sY3vtE2btxoc+fOte9973u2adMm6+npsebmZhsYGLClS5faF77wBaupqbFf/vKX1t3dPd6rjXHy7W9/2971rndZU1OTHXHEEUN383R3d1tLS4v19fXZn//8Z/vEJz5h6XTafv7zn4/3KkempaXF3v72t1tTU5MddNBBdvvtt1tXV5e1trZad3e3rV+/3n74wx8O3UG0N9x+++3W19dn559/vpWXl9u999474jtiLrjggqFjWVNTkzU3N9uVV15p8Xjcli9fbh/60IfGeO1hNvzavaGhwXp7e62hocF+/etf25lnnmn9/f123XXX2ZIlS6y/v3+8V3evO+6442zZsmX2wAMP7PLY4DXD6173OjvhhBP29qqNm3GfcPJMnTrVrrnmGnvjG99oZmZ33313pMvv6ekxM5v0f0KXjwMPPNAuvfRSe+655+z88883M7P//u//HpM/axvcvmb71zYeL4OTIO9617vsve99r5mZ/exnP5PP39f7f2FhoZ144on2rW99y5544gmrq6uz7u5ue8c73jEmt1zv69sT4e6//35btmyZmZnddddddskll1hFRcXQ49OnT7d3v/vd9rvf/c6uv/76ofppp51mZmaPP/64+6fjgxNJl112mSUSid1OOB1//PFWUFAwonXe22MEiMratWvtoosuskwmY6eddpo999xz9uEPf3jYF1+JRMKOOeYY++IXv2jr1q2zj3zkI3zxtZ964okn7JOf/KSZvfol89/+9jd7z3veY1OmTBl6TkFBgZ166qn2rW99y9auXWvnnXfeeK1u5G677TZrbGy0wsJCe/DBB+2d73ynFRcXDz0+Z84cu/jii+2hhx6yT33qU3tlnQbPWT/wgQ/YO97xDstkMnbrrbeOallVVVV21VVX2Qc/+EEze/V6MezPzzF2pk2bZueee6498MADdt1115nZqzeN7OnNDfua/faaYbxurdrd7dJBEASf+tSnAjMLDj30UPmc1atXBx/5yEeC+fPnB+l0OigvLw+OP/744Prrr9/lFurB29S8f/X19bss+7bbbguWLFkSVFdXBwUFBUF9fX1w8cUXBytXrnTXZfC2u8H3dNNNNwUnnXRSUFFREZhZ8Mwzzww9N5vNBjfeeGNw5plnBjU1NUEqlQpmzZoVvO997wuef/55+X7DDN5uu7s/heru7g4WLFgQmFmwaNEiuZyHHnooWL9+ffChD30omDNnTpBMJoNzzjln6HmD227t2rVBEATB2rVr5fYdXK+wx3deFkYml8sNfV7PPvts0NraGqTT6aCgoCBoamoa9tyd/8TG+7fzbaPq32v19vYG3/zmN4MTTzwxqKysDAoLC4MDDjgguPTSS+VnufPtok1NTcEnP/nJYP78+UFhYaHbHz07v5fd9Zn77rtv6Lnf+MY33OUMjv/f/e53wZIlS4ZuP7/jjjuCINh1bAdBsNv+vLvtGbbvw+Txta99LTCzoLa2Nq/XrVy5cqgvPPnkk7s8fvbZZwdmFixdujQ46qijgng8HrS2tu7yvIMOOigws+ALX/jCsHpUYwQYD+oc8ZJLLgnMLKisrOTPZ7BbS5YsCcwsOOCAA/bo5zl2/imITCYTfPOb3wyOOuqooT+bHvx5jh07dgTf/va3g7e+9a3BggULguLi4qCsrCw46qijgquvvjro6OgIbeeBBx4I3vCGNwRlZWVBeXl5cMoppwS/+c1vgiAY3Z/UffSjHw3MLDj++ONH9b6j/pO61atXB2YWTJ06NRgYGAjuvffewMyCY445Zo/W4/777x9q/6677trtumJ0RnLtPui9731vYGZBYWFhsGXLll0ez+f6fWejuX7e+adCuru7g89//vPBggULgsLCwmD69OnBBz7wAffnYYJgdH9S99pri9cux/u3u2s0b55iMpmQdzgNevHFF83s1btzPLfffrsdeuih9t3vftdWr15tiUTCuru77YknnrBPfOIT9vrXv946OjqGnl9dXW21tbWWSqXMzKy8vHzox5IHf6zLzCybzdp73/tee9e73mX333+/tbe3W3Fxsa1fv95+9KMf2RFHHGF33XVX6Lp/9KMftYsuusieeOKJXX5srK2tzd7whjfYBz7wAXvwwQetpaXF0um0bdq0yX7+85/b4sWL7bbbbhv1dtudoqIi+8QnPmFmZs89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F6xatcoee+wxmz59+tCPJL/WvHnz7IQTTrBsNmv/93//N+L1+dOf/mQdHR1WUlJi//Zv/7bL40VFRUM/QPirX/3KXUYikRj6k7XX+slPfmJmZpdeeunQn+K81nve8x4zM/fX7aM0mNCnbu/953/+58l/C98+7Le//a21tbXZscceO+zPTtPptL3jHe8ws/AfD98Tg/343/7t3+SfQe6uH5911ll2yCGHjMn6vdbgnxGa6f6+t34wE/uWWCxmd911l73nPe+xWCxmnZ2d9rvf/c4++9nP2hve8AarrKy0c88915555pldXjv4Z3CNjY3D/pzgkUceMTOzU045xczMZs2aZfX19bZ06dJhf7Y3+LzBHyDfEyMZI8B4amlpGfrvnfvrzr785S/b9OnTd/kXddoxJr7B/lJZWSl/NP7SSy91+8trf5JgUE1NjV144YWjWp/6+no79NBDrbe315599tmhei6Xs9/+9rdmZvbJT37S/XmBT3/606Nqs6ioyB588EF705veZGavXlfdfvvt9qlPfcpOOeUUq6qqsgsvvNBWr14dupzBFLKwf7szeD76rne9a9jncdJJJ9ncuXNtw4YNoT/D8FqZTMaWLVtml156qd1+++1m9uoPw0+bNm3Ey8DYGtxPD55T7Mn1exTXz3PnzrV3vetdbpsXXHCBmZn9+te/HslbQ57GfcLp9NNPt+DVO60sCALr7++3lStX2rXXXmvr16+3iy66yK6++uphr3n88cfN7NUOPGPGDPdgMX369KHfu9i4ceOI1+fpp582s1cjDVWHfv3rXz/U/oYNG3Z5/MADDxz2O0beun/+85+X6z04WZDPeo+F/SmucTIaTPp497vfvctjg7WxiPfNZDJD8ekXXnih7Mcf//jHzUz344nUv4qKiux1r3vdeK8GJqnKykq7+eabbfXq1fbf//3fds455wylZg0MDNgdd9xhxx13nN18883DXnfEEUcMTfzv/DtOf/nLXyyZTA4bIyeffLL19/fbk08+aWZmHR0dQxcte/L7TcC+pKOjw70Y7uzsHO9VwwTU2trq9ped05Z3dswxx+z29yaff/55+5d/+Rc7+OCDrbS0dOh3XGOxmD333HNmNvw3ldasWTP0Zbv68uCEE04Y9e9czpo1y+6991574YUX7Oqrr7Y3v/nNQ18md3d3209/+lM78sgj7cEH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LJlM2po1a+wDH/jA0O9PjoXBY/2KFSvcx6+88kr3IjIej9s555xjZmbf/OY33Wua0aYsLl26dLfnYH/84x+HvmB/7fEpCoPnn+eee27o+eqRRx5phx9+uGWzWbvlllsiXw/sPd/85jeHQlI++tGPDt2dtCfX71FcP69Zs8Z++ctf7lJfv3790I/an3feeaHLHmv76jXDhJxw6uzstJ/97Gd22WWXmdmrP6L32smd//mf/7GCggK799577c1vfrM9+eSTQzvygYEBe+qpp+yKK66wAw44IK+2S0tL7YorrjCzVw9UO5/Yr1692s4++2zbsGGDlZSUDD0vH295y1vs7W9/u2WzWTvrrLPs29/+9rCB0dDQYLfeequdccYZQ3chRWHNmjX2ve99z4488sih3xC54oor7Oyzz46sjZE67LDDzOzV3yAZi9t392W5XG5oJ37uuefu9vmDz7nnnnusqalpRG0Mfj733nvvsCSVnV188cV27LHHWmdnp5122mn2s5/9bFgK0MaNG+2GG26wxYsXD/v9tb2hv7/f/vrXv9q///u/23HHHWdbtmyx0tJSu/POO8flT4UGt+ett946LNIe+4aHH37Y5s2bZxdddJH94Q9/GHaS0NzcbN///vdtyZIlls1mbfr06e7JzOBdSr/61a8sCAL5Z86DE06DJ0wHHHDAqH5vaaKNEWCk5s2bZzfddJMlk0n785//bIsWLbLvf//7Q3eXmL36Rcfy5cvti1/84lCqI/ZPxx9//NCXxLfffrstXrzYbr755mF/npbNZu25556zyy+/fI/+XOfMM880s1f/QuLyyy+3jo4OM3v1vP5jH/uY/fjHP5Y/av2Zz3zGUqmULV261N7znvcM/Wldc3OzfexjH7N77rlnVPvmX/ziFzZ37ly77LLL7KGHHhr2Y+Xbtm2zr33ta3b++eeb2aupqWEpXqOxYsWKoTGYzzkrf1Y3+ezYscN+85vf2JIlS+yTn/ykmb36Z61f+cpXhj1vtNfvUVw/V1RU2MUXX2y/+MUvhia7nnjiCXvzm99sPT09dvjhh4dOODU2Nob+i2JCe/Ca4Te/+c24fmEfuWCcXHjhhYGZBalUKqitrR36V1NTE5jZ0L+amprgr3/9q7uMu+66KygrKxt6bjqdDqqrq4NEIjFsGa91+umnB2YW3Hjjje5yM5lM8O53v3vo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",
      "text/plain": [
       "<Figure size 1200x600 with 18 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "data = filter_explanations([5,7,9],[6,1,3],all_attributions_ig,all_attributions_dl,all_attributions_gs,all_labels)\n",
    "fig = plot_MNIST_explanations(3,6,data)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Second ViT model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  7%|▋         | 1/15 [00:19<04:27, 19.11s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 1 | Train Loss: 0.58614 | Train Accuracy: 0.82868 | Val Loss: 0.18049 | Val Accuracy: 0.95213\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 13%|█▎        | 2/15 [00:37<04:04, 18.80s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 2 | Train Loss: 0.19785 | Train Accuracy: 0.94339 | Val Loss: 0.12639 | Val Accuracy: 0.96393\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 20%|██        | 3/15 [00:55<03:42, 18.53s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 3 | Train Loss: 0.14493 | Train Accuracy: 0.95640 | Val Loss: 0.09967 | Val Accuracy: 0.96809\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 27%|██▋       | 4/15 [01:14<03:23, 18.53s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 4 | Train Loss: 0.11949 | Train Accuracy: 0.96323 | Val Loss: 0.08961 | Val Accuracy: 0.97291\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 33%|███▎      | 5/15 [01:34<03:10, 19.04s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 5 | Train Loss: 0.09859 | Train Accuracy: 0.96997 | Val Loss: 0.08896 | Val Accuracy: 0.97357\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 40%|████      | 6/15 [01:57<03:03, 20.42s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 6 | Train Loss: 0.08807 | Train Accuracy: 0.97221 | Val Loss: 0.07903 | Val Accuracy: 0.97540\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 47%|████▋     | 7/15 [02:15<02:37, 19.74s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 7 | Train Loss: 0.07868 | Train Accuracy: 0.97571 | Val Loss: 0.07771 | Val Accuracy: 0.97806\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 53%|█████▎    | 8/15 [02:35<02:16, 19.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 8 | Train Loss: 0.06964 | Train Accuracy: 0.97754 | Val Loss: 0.07062 | Val Accuracy: 0.97856\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 60%|██████    | 9/15 [02:57<02:02, 20.36s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 9 | Train Loss: 0.06114 | Train Accuracy: 0.98002 | Val Loss: 0.06425 | Val Accuracy: 0.98138\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 67%|██████▋   | 10/15 [03:18<01:43, 20.74s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 10 | Train Loss: 0.05730 | Train Accuracy: 0.98147 | Val Loss: 0.06863 | Val Accuracy: 0.97955\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 73%|███████▎  | 11/15 [03:38<01:22, 20.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 11 | Train Loss: 0.05020 | Train Accuracy: 0.98391 | Val Loss: 0.06688 | Val Accuracy: 0.98039\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 80%|████████  | 12/15 [03:59<01:02, 20.70s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 12 | Train Loss: 0.04727 | Train Accuracy: 0.98480 | Val Loss: 0.06569 | Val Accuracy: 0.98072\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 87%|████████▋ | 13/15 [04:19<00:40, 20.47s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 13 | Train Loss: 0.04367 | Train Accuracy: 0.98569 | Val Loss: 0.06458 | Val Accuracy: 0.98388\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 93%|█████████▎| 14/15 [04:40<00:20, 20.67s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 14 | Train Loss: 0.03777 | Train Accuracy: 0.98774 | Val Loss: 0.06079 | Val Accuracy: 0.98338\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 15/15 [05:02<00:00, 20.17s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 15 | Train Loss: 0.03673 | Train Accuracy: 0.98793 | Val Loss: 0.06420 | Val Accuracy: 0.98321\n",
      "Saving the model: models\\ViT_v2_mnist.pth\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "# Experiment tracking setup\n",
    "timestamp = datetime.now().strftime(\"%Y-%m-%d\")\n",
    "experiment_name = \"MNIST\"\n",
    "model_name = \"VisionTransformer_v2\"\n",
    "log_dir = os.path.join(\"runs\", timestamp, experiment_name, model_name)\n",
    "writer = SummaryWriter(log_dir)\n",
    "\n",
    "# Device setup\n",
    "device = 'cuda' if torch.cuda.is_available() else 'cpu'\n",
    "\n",
    "model_vit = ViT(\n",
    "    image_size=28,       # MNIST images are 28x28\n",
    "    patch_size=7,        # 4 patches per dimension (28/7)\n",
    "    num_classes=10,      # 10 output classes for digits 0-9\n",
    "    dim=64,             # Embedding dimension\n",
    "    depth=6,             # Number of transformer layers\n",
    "    heads=8,             # Number of attention heads\n",
    "    mlp_dim=128,         # Hidden dimension in MLP layers\n",
    "    dropout=0.1,         # Dropout rate in transformer\n",
    "    emb_dropout=0.1,     # Dropout rate for embeddings\n",
    "    channels = 1\n",
    ").to(device)\n",
    "\n",
    "loss_fn = nn.CrossEntropyLoss()\n",
    "optimizer = optim.Adam(model_vit.parameters(), lr=1e-4)\n",
    "\n",
    "\n",
    "\n",
    "accuracy = Accuracy(task='multiclass', num_classes=10).to(device)\n",
    "# Training and Validation Loops\n",
    "EPOCHS = 15\n",
    "for epoch in tqdm(range(EPOCHS)):\n",
    "    # Training Loop\n",
    "    train_loss, train_acc = 0.0, 0.0\n",
    "    model_vit.train()\n",
    "    torch.manual_seed(epoch)\n",
    "    for X, y in train_dataloader:\n",
    "        X, y = X.to(device), y.to(device)\n",
    "       # print(X.shape)\n",
    "        optimizer.zero_grad()\n",
    "        \n",
    "        # Forward pass\n",
    "        y_pred = model_vit(X)\n",
    "        loss = loss_fn(y_pred, y)\n",
    "        train_loss += loss.item()\n",
    "        train_acc += accuracy(y_pred, y)\n",
    "        \n",
    "        # Backward pass and optimization\n",
    "        loss.backward()\n",
    "        optimizer.step()\n",
    "\n",
    "    # Average metrics\n",
    "    train_loss /= len(train_dataloader)\n",
    "    train_acc /= len(train_dataloader)\n",
    "\n",
    "    # Validation Loop\n",
    "    val_loss, val_acc = 0.0, 0.0\n",
    "    model_vit.eval()\n",
    "    torch.manual_seed(epoch)\n",
    "    with torch.no_grad():\n",
    "        for X, y in val_dataloader:\n",
    "            X, y = X.to(device), y.to(device)\n",
    "            \n",
    "            # Forward pass\n",
    "            y_pred = model_vit(X)\n",
    "            loss = loss_fn(y_pred, y)\n",
    "            val_loss += loss.item()\n",
    "            val_acc += accuracy(y_pred, y)\n",
    "\n",
    "    # Average metrics\n",
    "    val_loss /= len(val_dataloader)\n",
    "    val_acc /= len(val_dataloader)\n",
    "\n",
    "    # Log metrics to TensorBoard\n",
    "    writer.add_scalars(main_tag=\"Loss\", tag_scalar_dict={\"train/loss\": train_loss, \"val/loss\": val_loss}, global_step=epoch)\n",
    "    writer.add_scalars(main_tag=\"Accuracy\", tag_scalar_dict={\"train/acc\": train_acc, \"val/acc\": val_acc}, global_step=epoch)\n",
    "\n",
    "    # Print progress\n",
    "    print(f\"Epoch: {epoch+1} | Train Loss: {train_loss:.5f} | Train Accuracy: {train_acc:.5f} | Val Loss: {val_loss:.5f} | Val Accuracy: {val_acc:.5f}\")\n",
    "\n",
    "\n",
    "MODEL_PATH = Path(\"models\")\n",
    "MODEL_PATH.mkdir(parents=True, exist_ok=True)\n",
    "MODEL_NAME = \"ViT_v2_mnist.pth\"\n",
    "MODEL_SAVE_PATH = MODEL_PATH / MODEL_NAME\n",
    "#Saving the model\n",
    "print(f\"Saving the model: {MODEL_SAVE_PATH}\")\n",
    "torch.save(obj=model_vit.state_dict(), f=MODEL_SAVE_PATH)  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_12588/3303951566.py:19: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  model_ViT_mnist_loaded_v2.load_state_dict(torch.load(MODEL_SAVE_PATH))\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<All keys matched successfully>"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "MODEL_PATH = Path(\"models\")\n",
    "MODEL_PATH.mkdir(parents=True, exist_ok=True)\n",
    "MODEL_NAME = \"ViT_v2_mnist.pth\"\n",
    "MODEL_SAVE_PATH = MODEL_PATH / MODEL_NAME\n",
    "\n",
    "#Loading the saved model\n",
    "model_ViT_mnist_loaded_v2 = ViT(\n",
    "    image_size=28,       # MNIST images are 28x28\n",
    "    patch_size=7,        # 4 patches per dimension (28/7)\n",
    "    num_classes=10,      # 10 output classes for digits 0-9\n",
    "    dim=64,             # Embedding dimension\n",
    "    depth=6,             # Number of transformer layers\n",
    "    heads=8,             # Number of attention heads\n",
    "    mlp_dim=128,         # Hidden dimension in MLP layers\n",
    "    dropout=0.1,         # Dropout rate in transformer\n",
    "    emb_dropout=0.1,     # Dropout rate for embeddings\n",
    "    channels = 1\n",
    ").to(device)\n",
    "model_ViT_mnist_loaded_v2.load_state_dict(torch.load(MODEL_SAVE_PATH))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 313/313 [01:04<00:00,  4.84it/s]\n"
     ]
    }
   ],
   "source": [
    "model_loaded = model_ViT_mnist_loaded_v2.to(device)\n",
    "\n",
    "ig = IntegratedGradients(model_loaded)\n",
    "gs = GradientShap(model_loaded)\n",
    "dl = DeepLift(model_loaded)\n",
    "\n",
    "all_attributions_ig = []\n",
    "all_labels = []\n",
    "all_attributions_gs = []\n",
    "all_attributions_ks = []\n",
    "all_attributions_dl = []\n",
    "all_batches= []\n",
    "model_loaded.eval()\n",
    "torch.manual_seed(210)\n",
    "for batch_samples, batch_labels in tqdm(test_dataloader):\n",
    "    # Ensure samples have the correct shape\n",
    "    batch_labels = batch_labels.to(device)\n",
    "    batch_samples = batch_samples.requires_grad_().to(device) # Enable gradients for attribution\n",
    "    baseline_dist = torch.zeros((batch_samples.shape[0],1,28,28)).to(device)\n",
    "    \n",
    "\n",
    "    # Calculate the attributions for each sample in the batch\n",
    "    attributions, deltas = ig.attribute(batch_samples, target=batch_labels, return_convergence_delta=True)\n",
    "\n",
    "    \n",
    "    # Append attributions and labels for further analysis\n",
    "\n",
    "    all_attributions_ig.append(attributions)\n",
    "    all_labels.append(batch_labels)\n",
    "    all_batches.append(batch_samples.detach())\n",
    "    attributions_gs, deltas = gs.attribute(batch_samples, target=batch_labels,  baselines=baseline_dist,return_convergence_delta=True)\n",
    "    all_attributions_gs.append(attributions_gs)\n",
    "    \n",
    "\n",
    "    attributions_dl = dl.attribute(batch_samples, target=batch_labels)\n",
    "    all_attributions_dl.append(attributions_dl)\n",
    "\n",
    "\n",
    "# Concatenate all attributions and labels\n",
    "all_attributions_ig = torch.cat(all_attributions_ig, dim=0)  \n",
    "all_labels = torch.cat(all_labels, dim=0)\n",
    "\n",
    "all_attributions_gs = torch.cat(all_attributions_gs, dim=0)\n",
    "all_attributions_dl = torch.cat(all_attributions_dl, dim=0)\n",
    "\n",
    "all_batches = torch.cat(all_batches,dim=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABJwAAAJPCAYAAAA5VM5nAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8ekN5oAAAACXBIWXMAAA9hAAAPYQGoP6dpAACnpklEQVR4nOzdd5ydZZ3///dp01tmkkwy6YRA6CV0pMfG0mQRsLCg4C5YFgvfFVddWFEsKyKra0MFRYpYQEHpBKWG0GtI75nJ9N7OOffvD34zZsjncydnck8yk7yej0ceD/jMOfd1n/tc112uued+x4IgCAQAAAAAAABEJL6zVwAAAAAAAAC7FiacAAAAAAAAECkmnAAAAAAAABApJpwAAAAAAAAQKSacAAAAAAAAECkmnAAAAAAAABApJpwAAAAAAAAQKSacAAAAAAAAECkmnAAAAAAAABCp3XbCadGiRTr99NM1fvx4xeNxxWIxXX311Tt7tcaUWCymWCymVatWbfGzIAj0wx/+UAcffLCKiopCX4sdr6+vT9dcc4322WcfFRQUDH4/sN18882KxWI68cQTzZ/X1tbqkksu0bRp05RKpUJfCwAAkIuZM2cqFovpscce29mrAiDEY489plgsppkzZ5o/b29v1+c//3nNnj1beXl5oa/dVey0CaeLLrpo8CJ383/JZFITJkzQySefrJ/+9KdKp9ORt7106VKdeOKJuvfee9Xc3Kzx48erurpaJSUlkbe1Iw0cjDb/V1RUpMmTJ+vQQw/VJZdcottuu029vb0jvi7XXnutPvOZz+jll19WEASqrq5WdXW1EomEHnvsMV199dW6++67R3w9dhf/93//N/idf/KTn9zq6z/1qU/pv/7rv7R48WIlk8nB70eS7r77bl199dWj+qRmYGe++b94PK7y8nJNnz5dp5xyiq688kotWrRoxNclnU7r5JNP1i9+8QutW7dOpaWlqq6uVmVlpSTp+9//vq6++momW3dxHR0duu6663TcccepqqpKeXl5qq6u1sEHH6yPfOQjg/1DkjZu3DjYbx999FF3mSeffPLg6zZs2OC+rqamRrFYTN/85jcHa6NpjAC5GjhHDJu47+vr00033aRzzjlHs2bNUklJiQoKClRTU6N3v/vduuaaa7R06dIdt9IY1To6OvSDH/xAp512mqZPn66ioiIVFRVp2rRp+qd/+iddd911g/voXU19fb2uvvpqHXnkkaqoqFBeXp5qamo0b948XXLJJbr11ltVX1+/xftOPPFExWIxXXTRRVttY+A4c/PNN2/1tR/84AcHX3/nnXdu9fUD67H5v0QiocrKSh177LH67ne/q87Ozq0uB9vHunbPy8vThAkTNHfuXJ133nm64YYbzL40Vg38wjnKX8qfffbZuv7667VixQoVFhaqurpaEyZMGGzv6quv1ksvvRRZe6NCsJNceOGFgaQglUoF1dXVg/9KS0sDSYP/3vWudwWdnZ2Rtn3FFVcEkoLjjjsuaG5ujnTZO9OMGTMCSUFxcfHg9qyqqgqSyeSQbVpVVRX88pe/3O729t5772DvvfcO1q1bt8XPJkyYEEgKvve97wXZbHbIz6666qpAUnDhhRdu9zrgbUccccTg91tZWRn09va6r21paRnsE3/4wx+2+PnA2LzqqqtGcI23z4IFCwY/7/jx4939h6Tg6KOPDhYvXrxd7f3xj38M9t577+CCCy7Y4mf33nvv4HZfsmTJFj8fGJcLFizYrnXA6LV48eLB73ngX2lpaVBSUjKkdvHFFw++Z/bs2YGk4L//+7/NZfb19QVFRUWD7/3tb39rvm7ZsmWDr3niiScG6zt6jABRGjgOnXDCCebPH3300WDatGlD+nFBQUEwbty4IBaLDdZisVjwwQ9+MPSYiF3fHXfcEVRVVQ3pL4WFhUFFRcWQWjKZDD71qU/t7NU1Dfdc4oknntjis5eXlweFhYVDatdcc80W7z3hhBO2+Xx9YDk33XRT6Ouam5uD/Pz8wdefdtppW132wHoUFBQMHssqKyuHrP/ee+8dbNy4cavLwvBZ1+4TJ04c8n1KCvLy8oIvfOELQU9Pz85e5e120003DX6ubbVw4cJg7733Dk4++eQtfvbaa68NbsOnn356i58P9PWtjaOxZqf/Sd0xxxyj2trawX9tbW3atGmTvvSlL0mSnnjiCX33u9+NtM3XX39dknTuueeqoqIi0mWPBldcccXg9mxoaFB/f7+WLl2qH//4x9prr73U2Nioj3/84/qP//iP7Wpn8eLFWrx4saZMmTKkvmnTpsHZ7U984hP8qdYIW7JkiZ599lnNmDFD8+fPV1NTk/7yl7+4r3/rrbeUTqdVVVWls88+eweu6chYtGjRkP1HT0+PnnrqKV1++eUqKirS008/rUMPPXS77uT4wAc+oMWLF+vXv/71Fj8b2J+cdNJJmjNnzrDbwNjU39+vs846S6tXr9bkyZN14403qqWlRW1tbWpvb9fGjRt122236fTTT1cikRh833HHHSdJevzxx83lPv/88+rq6hq889B73UC9oKBAhx9+uPmaHTFGgB3lrrvu0nve8x6tXbtWM2fO1E9+8hOtW7dO3d3dampqUn9/vxYtWqSvfvWrqqqq0u9+9zt1dXXt7NXGTvKDH/xA559/vhobG3XAAQcM3s3T1dWl5uZm9fb26u9//7suv/xyFRQU6De/+c3OXuXINDc366yzzlJjY6P22msv3Xnnners7FRLS4u6urq0evVq/fznPx+8g2hHuPPOO9Xb26tzzz1XZWVluv/++7f5jpjzzjtv8FjW2NiopqYmXXXVVYrH43rrrbf0iU98YoTXHtLQa/e6ujr19PSorq5Of/jDH3TyySerr69P1113nebPn6++vr6dvbo73BFHHKHFixfrkUce2eJnA9cMBx54oI466qgdvWo7zU6fcLJMmDBB1157rd7znvdIku69995Il9/d3S1JY/5P6HKx55576tJLL9XLL7+sc889V5L0P//zPyPyZ20D21favbbxzjIwCXL++efrIx/5iCTplltucV+/q/f//Px8HX300fr+97+vhQsXqqamRl1dXfrABz4wIrdc7+rbE+EefvhhLV68WJJ0zz336JJLLlF5efngzydNmqQPfehD+vOf/6wbbrhhsH788cdLkp5++mnzT8cHJpI+/elPK5FIbHXC6cgjj1ReXt42rfOOHiNAVFauXKmLLrpI6XRaxx9/vF5++WX927/925BffCUSCR122GH62te+plWrVumyyy7jF1+7qYULF+rzn/+8pLd/yfzcc8/pwx/+sMaPHz/4mry8PB133HH6/ve/r5UrV+qcc87ZWasbuTvuuEMNDQ3Kz8/Xo48+qg9+8IMqKioa/Pn06dN18cUXa8GCBfrCF76wQ9Zp4Jz1Yx/7mD7wgQ8onU7r9ttvH9ayxo0bp6uvvlof//jHJb19vRj25+cYORMnTtTZZ5+tRx55RNddd52kt28a2d6bG3Y1u+01w866tWprt0sHQRB84QtfCCQF++67r/ua5cuXB5dddlkwe/bsoKCgICgrKwuOPPLI4IYbbtjiFuqB29SsfzNmzNhi2XfccUcwf/78oLKyMsjLywtmzJgRXHzxxcHSpUvNdRm47W7gM918883BMcccE5SXlweSghdffHHwtZlMJrjpppuCk08+OaiqqgpSqVQwderU4KMf/WjwyiuvuJ83zMDttlv7U6iurq5gzpw5gaTgoIMOcpezYMGCYPXq1cEnPvGJYPr06UEymQzOPPPMwdcNbLuVK1cGQRAEK1eudLfvwHqF/XzzZWHbZLPZwe/rpZdeClpaWoKCgoIgLy8vaGxsHPLazf/Exvq3+W2j3r936unpCa6//vrg6KOPDioqKoL8/Pxgjz32CC699FL3u9z8dtHGxsbg85//fDB79uwgPz/f7I+WzT/L1vrMQw89NPja733ve+ZyBsb/n//852D+/PmDt5/fddddQRBsObaDINhqf97a9gzb92Hs+M53vhNICqqrq3N639KlSwf7wrPPPrvFz88444xAUrBo0aLgkEMOCeLxeNDS0rLF6/baa69AUvDVr351SD2qMQLsDN454iWXXBJICioqKvjzGWzV/PnzA0nBHnvssV2P59j8URDpdDq4/vrrg0MOOWTwz6YHHs9RX18f/OAHPwhOO+20YM6cOUFRUVFQWloaHHLIIcE111wTtLe3h7bzyCOPBKecckpQWloalJWVBe9617uCP/7xj0EQDO9P6j75yU8GkoIjjzxyWJ876j+pW758eSApmDBhQtDf3x/cf//9gaTgsMMO2671ePjhhwfbv+eee7a6rhiebbl2H/CRj3wkkBTk5+cHGzZs2OLnuVy/b24418+bPyqkq6sr+MpXvhLMmTMnyM/PDyZNmhR87GMfMx8PEwTD+5O6d15bvHM51r+tXaNZ8xRjyai8w2nAa6+9Juntu3Msd955p/bdd1/9+Mc/1vLly5VIJNTV1aWFCxfq8ssv10knnaT29vbB11dWVqq6ulqpVEqSVFZWNviw5IGHdUlSJpPRRz7yEZ1//vl6+OGH1dbWpqKiIq1evVq/+MUvdMABB+iee+4JXfdPfvKTuuiii7Rw4cItHjbW2tqqU045RR/72Mf06KOPqrm5WQUFBVq3bp1+85vfaN68ebrjjjuGvd22prCwUJdffrkk6eWXX9Ybb7xhvm7x4sU65JBDdOONN6qpqUnJZDJ0uYlEQtXV1UN+czSwfQceyl5dXa3i4mJJb/8JyOY/H3io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g3+K804f/vCHJcl8un2UBhL6vNt7/+Vf/mXs38K3C/vTn/6k1tZWHX744UP+7LSgoEAf+MAHJIU/PHx7DPTjz372s+6fQW6tH5966qnaZ599RmT93mngzwglv7/vqAdmYtcSi8V0zz336MMf/rBisZg6Ojr05z//Wf/5n/+pU045RRUVFTr77LP14osvbvHegT+Da2hoGPLnBE888YQk6V3vepckaerUqZoxY4YWLVo05M/2Bl438ADy7bEtYwTYmZqbmwf/e/P+urlvfOMbmjRp0hb/ok47xug30F8qKirch8ZfeumlZn955yMJBlRVVenCCy8c1vrMmDFD++67r3p6evTSSy8N1rPZrP70pz9Jkj7/+c+bjxf44he/OKw2CwsL9eijj+q9732vpLevq+6880594Qtf0Lve9S6NGzdOF154oZYvXx66nIEUsrB/WzNwPnr++ecP+T6OOeYYzZw5U2vWrAl9DMM7pdNpLV68WJdeeqnuvPNOSW8/GH7ixInbvAyMrIH99MA5xfZcv0dx/Txz5kydf/75ZpvnnXeeJOkPf/jDtnw05GinTzidcMIJCt6+00pBEKivr09Lly7Vt7/9ba1evVoXXXSRrrnmmiHvefrppyW93YEnT55sHiwmTZo0+LyLtWvXbvP6vPDCC5LejjT0OvRJJ5002P6aNWu2+Pmee+455DlG1rp/5Stfcdd7YLIgl/UeCbtTXONYNJD08aEPfWiLnw3URiLeN51OD8anX3jhhW4//vd//3dJfj8eTf2rsLBQBx544M5eDYxRFRUVuvXWW7V8+XL9z//8j84888zB1Kz+/n7dddddOuKII3TrrbcOed8BBxwwOPG/+XOcHn/8cSWTySFj5Nhjj1VfX5+effZZSVJ7e/vgRcv2PL8J2JW0t7ebF8MdHR07e9UwCrW0tJj9ZfO05c0ddthhW33e5CuvvKJ//dd/1dy5c1VSUjL4HNdYLKaXX35Z0tBnKq1YsWLwl+3eLw+OOuqoYT/ncurUqbr//vv16quv6pprrtH73ve+wV8md3V16de//rUOPvhgPfroo+4yLrzwwiHXata/MJs/V9Q6Zx2YBNjaL0l/9atfDW7LVCqlffbZRz/96U8lSYcffrh+/OMfh74fO9f2XL9Hcf18wgknuOs28DPrl4PYfjt9wumdUqmU9txzT/3Hf/yHrr/+eknSNddco5UrVw6+ZmBH3dfXFzrbPvCb4K6urm1uv6GhQZKGROy+04wZMwb/27oDK+yuoIF1b2pqctd7YB28A14UgiBQS0uLJLkPL+buptGrrq5ODz74oOLx+OCs/OYGHsS4YsWKLR40vL2amprU19cn6e3+7/Xjgd8ueuNvR/avzX8zbvX3qqqqrT4kHNiaWbNm6YorrtDdd9+tdevWadWqVfrWt76l8vJypdNpXXLJJVq3bt3g6+PxuI499lhJ/5hwWrNmjdasWaODDz54yC893vm6p59+WplMRrFYLJIJp62NEWBn2/yups376+a+9a1vDbkIPuWUU3bU6mGUGegvLS0t7oTIHXfcMaS/zJ49O3SZWztvueWWWzRv3jzdeOONeuutt9TT0zMkMGTggcCdnZ2D7xk455c0GCTxTnl5ee4vsrfV/vvvr6985Su67777tGnTJr355pv60pe+pPz8fHV0dOhDH/pQTtdLubjnnnvU3NysvffeW4cccsgWPx+4M+UPf/hD6LXP5uEskydP1t57760zzzxTN910k5588kn3zkfsHAP76YFziu25fo/i+nnzh8t7P7Ou67H9RvUV1gUXXKBYLDb4G+IB2WxW0tsn4FubcQ+CQFdffXXObff29g57vcOS1gbW/aGHHtqmdR8py5YtG/yMs2bNMl9DYtzodfvttyudTiubzWrKlClDfoMWi8WUTCa1adMmSf+4EyoqA31YkpYuXbrVPrxq1SpzOTuyfw0kXqZSKXMymb6OkTBjxgx98Ytf1F/+8hfF43H19PQM3vo/YGCyaGAiaeDP5N45iTTw53XvfN1+++0XyQTR1sYIsLPNnTt38L9fffXVnbgmGAsG+ktPT4+WLVsWyTLDzhU2bdqkSy+9VOl0Wuecc45efvll9fb2qqmpSbW1taqtrdWRRx4pSSN6fr+t5s6dq2uvvVY33XSTpLfX//777x+RtgbuXHrrrbe2OF+NxWKDd5i3tbXp7rvvdpdz3nnnDW7LDRs2aPHixbr77rt10UUXDU7mYfQYOK8YuM7cnuv30XL9jOEZ1RNOBQUFg79NWLFixWB9IJ7d+nO27TXQXtiyV69evcXrt9VIrnsuHnjggcH/HriQwdiRyyTSnXfeuV0TqO9UVVU1eNK1s/vxthro74ceemgk0chALo499ljNmTNH0tuTtJsb+BOK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",
      "text/plain": [
       "<Figure size 1200x600 with 18 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "data = filter_explanations([5,7,9],[6,1,3],all_attributions_ig,all_attributions_dl,all_attributions_gs,all_labels)\n",
    "fig = plot_MNIST_explanations(3,6,data)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### CNN"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "class LeNet5V1(nn.Module):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.feature = nn.Sequential(\n",
    "            #1\n",
    "            nn.Conv2d(in_channels=1, out_channels=6, kernel_size=5, stride=1, padding=2),   # 28*28->32*32-->28*28\n",
    "            nn.Tanh(),\n",
    "            nn.AvgPool2d(kernel_size=2, stride=2),  # 14*14\n",
    "            \n",
    "            #2\n",
    "            nn.Conv2d(in_channels=6, out_channels=16, kernel_size=5, stride=1),  # 10*10\n",
    "            nn.Tanh(),\n",
    "            nn.AvgPool2d(kernel_size=2, stride=2),  # 5*5\n",
    "            \n",
    "        )\n",
    "        self.classifier = nn.Sequential(\n",
    "            nn.Flatten(),\n",
    "            nn.Linear(in_features=16*5*5, out_features=120),\n",
    "            nn.Tanh(),\n",
    "            nn.Linear(in_features=120, out_features=84),\n",
    "            nn.Tanh(),\n",
    "            nn.Linear(in_features=84, out_features=10),\n",
    "        )\n",
    "        \n",
    "    def forward(self, x):\n",
    "        return self.classifier(self.feature(x))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saving the model: models\\LENeT5_mnist.pth\n"
     ]
    }
   ],
   "source": [
    "# Experiment tracking setup\n",
    "timestamp = datetime.now().strftime(\"%Y-%m-%d\")\n",
    "experiment_name = \"MNIST\"\n",
    "model_name = \"LeNet5\"\n",
    "log_dir = os.path.join(\"runs\", timestamp, experiment_name, model_name)\n",
    "writer = SummaryWriter(log_dir)\n",
    "\n",
    "# Device setup\n",
    "device = 'cuda' if torch.cuda.is_available() else 'cpu'\n",
    "\n",
    "model_lenet5 = LeNet5V1().to(device)\n",
    "\n",
    "loss_fn = nn.CrossEntropyLoss()\n",
    "optimizer = optim.Adam(model_lenet5.parameters(), lr=1e-4)\n",
    "\n",
    "\n",
    "\n",
    "accuracy = Accuracy(task='multiclass', num_classes=10).to(device)\n",
    "# Training and Validation Loops\n",
    "EPOCHS = 15\n",
    "for epoch in tqdm(range(EPOCHS)):\n",
    "    # Training Loop\n",
    "    train_loss, train_acc = 0.0, 0.0\n",
    "    model_lenet5.train()\n",
    "    torch.manual_seed(epoch)\n",
    "    for X, y in train_dataloader:\n",
    "        X, y = X.to(device), y.to(device)\n",
    "       # print(X.shape)\n",
    "        optimizer.zero_grad()\n",
    "        \n",
    "        # Forward pass\n",
    "        y_pred = model_lenet5(X)\n",
    "        loss = loss_fn(y_pred, y)\n",
    "        train_loss += loss.item()\n",
    "        train_acc += accuracy(y_pred, y)\n",
    "        \n",
    "        # Backward pass and optimization\n",
    "        loss.backward()\n",
    "        optimizer.step()\n",
    "\n",
    "    # Average metrics\n",
    "    train_loss /= len(train_dataloader)\n",
    "    train_acc /= len(train_dataloader)\n",
    "\n",
    "    # Validation Loop\n",
    "    val_loss, val_acc = 0.0, 0.0\n",
    "    model_lenet5.eval()\n",
    "    torch.manual_seed(epoch)\n",
    "    with torch.no_grad():\n",
    "        for X, y in val_dataloader:\n",
    "            X, y = X.to(device), y.to(device)\n",
    "            \n",
    "            # Forward pass\n",
    "            y_pred = model_lenet5(X)\n",
    "            loss = loss_fn(y_pred, y)\n",
    "            val_loss += loss.item()\n",
    "            val_acc += accuracy(y_pred, y)\n",
    "\n",
    "    # Average metrics\n",
    "    val_loss /= len(val_dataloader)\n",
    "    val_acc /= len(val_dataloader)\n",
    "\n",
    "    # Log metrics to TensorBoard\n",
    "    writer.add_scalars(main_tag=\"Loss\", tag_scalar_dict={\"train/loss\": train_loss, \"val/loss\": val_loss}, global_step=epoch)\n",
    "    writer.add_scalars(main_tag=\"Accuracy\", tag_scalar_dict={\"train/acc\": train_acc, \"val/acc\": val_acc}, global_step=epoch)\n",
    "\n",
    "    # Print progress\n",
    "    print(f\"Epoch: {epoch+1} | Train Loss: {train_loss:.5f} | Train Accuracy: {train_acc:.5f} | Val Loss: {val_loss:.5f} | Val Accuracy: {val_acc:.5f}\")\n",
    "\n",
    "\n",
    "MODEL_PATH = Path(\"models\")\n",
    "MODEL_PATH.mkdir(parents=True, exist_ok=True)\n",
    "MODEL_NAME = \"LENeT5_mnist.pth\"\n",
    "MODEL_SAVE_PATH = MODEL_PATH / MODEL_NAME\n",
    "#Saving the model\n",
    "print(f\"Saving the model: {MODEL_SAVE_PATH}\")\n",
    "torch.save(obj=model_lenet5.state_dict(), f=MODEL_SAVE_PATH)  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_12588/3378268383.py:7: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  model_LeNet5_mnist_loaded.load_state_dict(torch.load(MODEL_SAVE_PATH))\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<All keys matched successfully>"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "MODEL_PATH = Path(\"models\")\n",
    "MODEL_PATH.mkdir(parents=True, exist_ok=True)\n",
    "MODEL_NAME = \"LENeT5_mnist.pth\"\n",
    "MODEL_SAVE_PATH = MODEL_PATH / MODEL_NAME\n",
    "\n",
    "model_LeNet5_mnist_loaded = LeNet5V1().to(device)\n",
    "model_LeNet5_mnist_loaded.load_state_dict(torch.load(MODEL_SAVE_PATH))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 313/313 [00:09<00:00, 33.16it/s]\n"
     ]
    }
   ],
   "source": [
    "model_loaded = model_LeNet5_mnist_loaded.to(device)\n",
    "\n",
    "ig = IntegratedGradients(model_loaded)\n",
    "gs = GradientShap(model_loaded)\n",
    "dl = DeepLift(model_loaded)\n",
    "\n",
    "all_attributions_ig = []\n",
    "all_labels = []\n",
    "all_attributions_gs = []\n",
    "all_attributions_ks = []\n",
    "all_attributions_dl = []\n",
    "all_batches= []\n",
    "model_loaded.eval()\n",
    "torch.manual_seed(210)\n",
    "for batch_samples, batch_labels in tqdm(test_dataloader):\n",
    "    # Ensure samples have the correct shape\n",
    "    batch_labels = batch_labels.to(device)\n",
    "    batch_samples = batch_samples.requires_grad_().to(device) # Enable gradients for attribution\n",
    "    baseline_dist = torch.zeros((batch_samples.shape[0],1,28,28)).to(device)\n",
    "    \n",
    "\n",
    "    # Calculate the attributions for each sample in the batch\n",
    "    attributions, deltas = ig.attribute(batch_samples, target=batch_labels, return_convergence_delta=True)\n",
    "\n",
    "    \n",
    "    # Append attributions and labels for further analysis\n",
    "\n",
    "    all_attributions_ig.append(attributions)\n",
    "    all_labels.append(batch_labels)\n",
    "    all_batches.append(batch_samples.detach())\n",
    "    attributions_gs, deltas = gs.attribute(batch_samples, target=batch_labels,  baselines=baseline_dist,return_convergence_delta=True)\n",
    "    all_attributions_gs.append(attributions_gs)\n",
    "    \n",
    "\n",
    "    attributions_dl = dl.attribute(batch_samples, target=batch_labels)\n",
    "    all_attributions_dl.append(attributions_dl)\n",
    "\n",
    "\n",
    "# Concatenate all attributions and labels\n",
    "all_attributions_ig = torch.cat(all_attributions_ig, dim=0)  \n",
    "all_labels = torch.cat(all_labels, dim=0)\n",
    "\n",
    "all_attributions_gs = torch.cat(all_attributions_gs, dim=0)\n",
    "all_attributions_dl = torch.cat(all_attributions_dl, dim=0)\n",
    "\n",
    "all_batches = torch.cat(all_batches,dim=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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//kf+fj169dbNpu1+vp6u+yyyw7jns6MtWvXTjp+jIyM2B/+8Ad773vfa2VlZfbAAw/YmWeeeUif5Hjta19r69ats+985zsH/Gz8ePKSl7zEVq5cOe0xMDeNjY3Za17zGtu+fbvNnz/fbrjhBuvt7bX+/n4bGBiwvXv32g9+8AN71ateZYlEYuL3XvSiF5mZ2e9//3t3u3/6058snU5PfPJQPW68XlJSYmeffbb7mMPRI8Dhcsstt9jLXvYy27lzpy1ZssS++tWv2q5du2x4eNi6u7ttbGzM1q5dax/5yEesvr7e/vu//9vS6fSR3m0cIV/+8pftDW94g3V1ddkpp5wy8WmedDptPT09Njo6ar/73e/sve99r5WUlNj3vve9I73Lkenp6bHXvOY11tXVZccdd5zdfPPNNjQ0ZL29vZZOp2379u32X//1XxOfIDocbr75ZhsdHbXLL7/cqqqq7I477pjyJ2KuuOKKiXNZV1eXdXd320c/+lGLx+O2fv16e8c73jHDew+zyffu7e3tNjIyYu3t7faTn/zELr74YstkMvbZz37W1qxZY5lM5kjv7mF3zjnn2Lp16+zuu+8+4Gfj9wynnnqqnXfeeYd7146YI77g5GlsbLRPfvKT9rKXvczMzG677bZItz88PGxmNuf/CV0hVqxYYddcc409/vjjdvnll5uZ2b//+7/PyD9rG399zY6t1/hIGV8EecMb3mBvfvObzczsu9/9rnz80T7/i4uL7fzzz7cvfOEL9tBDD1lLS4ul02l77WtfOyMfuT7aX0+Eu+uuu2zdunVmZnbrrbfa1VdfbdXV1RM/b25utje+8Y32i1/8wr74xS9O1C+88EIzM3vggQfcfzo+vpD0nve8xxKJxEEXnM4991wrKiqa0j4f7h4BorJ161a76qqrLJvN2oUXXmiPP/64/d3f/d2kP3wlEgk766yz7F//9V9t27Zt9s53vpM/fB2jHnroIXv/+99vZs/9kfmPf/yjvelNb7KGhoaJxxQVFdmLXvQi+8IXvmBbt261173udUdqdyN30003WWdnpxUXF9s999xjr3/9662srGzi54sXL7a3v/3tdu+999oHPvCBw7JP49esb33rW+21r32tZbNZ++EPfzitbdXW1tp1111nb3vb28zsufvFsH9+jpkzb948u+yyy+zuu++2z372s2b23IdG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",
      "text/plain": [
       "<Figure size 1200x600 with 18 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "data = filter_explanations([5,7,9],[6,1,3],all_attributions_ig,all_attributions_dl,all_attributions_gs,all_labels)\n",
    "fig = plot_MNIST_explanations(3,6,data)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "torch",
   "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.12.3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
