{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "FutureWarning: Using `TRANSFORMERS_CACHE` is deprecated and will be removed in v5 of Transformers. Use `HF_HOME` instead.\n",
      "  warnings.warn(\n",
      "2024-05-10:17:10:47,039 INFO     [utils.py:145] Note: detected 128 virtual cores but NumExpr set to maximum of 64, check \"NUMEXPR_MAX_THREADS\" environment variable.\n",
      "2024-05-10:17:10:47,040 INFO     [utils.py:148] Note: NumExpr detected 128 cores but \"NUMEXPR_MAX_THREADS\" not set, so enforcing safe limit of 8.\n",
      "2024-05-10:17:10:47,040 INFO     [utils.py:161] NumExpr defaulting to 8 threads.\n",
      "2024-05-10:17:10:47,374 INFO     [config.py:58] PyTorch version 2.1.1+cu118 available.\n"
     ]
    }
   ],
   "source": [
    "import torch\n",
    "import transformers\n",
    "from transformers import AutoTokenizer\n",
    "from mamba_ssm.models.mixer_seq_simple import MambaLMHeadModel\n",
    "from lm_eval.models.huggingface import HFLM\n",
    "from lm_eval.api.model import LM\n",
    "from lm_eval.api.registry import register_model\n",
    "import matplotlib.pyplot as plt\n",
    "def normalize_attn_mat(attn_mat):\n",
    "    return (attn_mat - torch.min(attn_mat)) / (torch.max(attn_mat) - torch.min(attn_mat))\n",
    "import warnings\n",
    "warnings.filterwarnings('ignore')\n",
    "warnings.filterwarnings(\"ignore\", category=DeprecationWarning)\n",
    "warnings.filterwarnings(\"ignore\", category=FutureWarning)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Define and load a pretrained Mamba-based LLM:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "class MambaEvalWrapper(HFLM):\n",
    "    AUTO_MODEL_CLASS = transformers.AutoModelForCausalLM\n",
    "    def __init__(self, pretrained=\"state-spaces/mamba-2.8b\", max_length=2048, batch_size=None, device=\"cuda\",dtype=torch.float16):\n",
    "        LM.__init__(self)\n",
    "        self._model = MambaLMHeadModel.from_pretrained(pretrained, device=device, dtype=dtype)\n",
    "        self.tokenizer = AutoTokenizer.from_pretrained(\"EleutherAI/gpt-neox-20b\")\n",
    "        self.tokenizer.pad_token_id = self.tokenizer.eos_token_id\n",
    "        self.vocab_size = self.tokenizer.vocab_size\n",
    "        self._batch_size = int(batch_size) if batch_size is not None else 64\n",
    "        self._max_length = max_length\n",
    "        self._device = torch.device(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Special tokens have been added in the vocabulary, make sure the associated word embeddings are fine-tuned or trained.\n"
     ]
    }
   ],
   "source": [
    "model = MambaEvalWrapper()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "prompt = \"Alice was beginning to get very tired of sitting by her sister on the bank\"#, and of having nothing to do: once or twice she had peeped into the book her sister was reading, but it had no pictures or conversations in it, “and what is the use of a book,” thought Alice “without pictures or conversations?” So she was considering in her own mind (as well as she could, for the hot day made her feel very sleepy and stupid), whether the pleasure of making a daisy-chain would be worth the trouble of getting up and picking the daisies, when suddenly a White Rabbit with pink eyes\"# ran close by her. There was nothing so very remarkable in that; nor did Alice think it so very much out of the way to hear the Rabbit say to itself, “Oh dear! Oh dear! I shall be late!” (when she thought it over afterwards, it occurred to her that she ought to have wondered at this, but at the time it all seemed quite natural); but when the Rabbit actually took a watch out of its waistcoat-pocket, and looked at it, and then hurried on, Alice started to her feet, for it flashed across her mind that she had never before seen a rabbit with either a waistcoat-pocket, or a watch to take out of it, and burning with curiosity, she ran across the field after it, and fortunately was just in time to see it pop down a large rabbit-hole under the hedge. In another moment down went Alice after it, never once considering how in the world she was to get out again. The rabbit-hole went straight on like a tunnel for some way, and then dipped suddenly down, so suddenly that Alice had not a moment to think about stopping herself before she found herself falling down a very deep well. Either the well was very deep, or she fell very slowly, for she had plenty of time as she went down to look about her and to wonder what was going to happen next. First, she tried to look down and make out what she was coming to, but it was too dark to see anything; then she looked at the sides of the well, and noticed that they were filled with cupboards and book-shelves; here and there she saw maps and pictures hung upon pegs. She took down a jar from one of the shelves as she passed; it was labelled “ORANGE MARMALADE”, but to her great disappointment it was empty: she did not like to drop the jar for fear of killing somebody underneath, so managed to put it\""
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Extraction of Attention Maps:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "input_tensor = model.tokenizer(prompt, return_tensors=\"pt\")['input_ids'].cuda()\n",
    "selected_chan = [1,2,3,4,5,6,7]\n",
    "selected_layer = 8\n",
    "model._model.backbone.layers[selected_layer].mixer.compute_attn_matrix = True"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "model._model = model._model.cuda()\n",
    "out = model._model(input_tensor)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAxsAAAByCAYAAAA7zczGAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8fJSN1AAAACXBIWXMAAA9hAAAPYQGoP6dpAAAQ0ElEQVR4nO3dWYwcV73H8XOqunt2j2fsMHgjY8fORkJIHCUgpMsNYANBLAISQCARIQVBhBAgkNBFvPEE4RWBEAKhCw/XEiBlAUIESkgcEjCZJF5ixx4vY8d2POPZPONZuurcB66EdPv3j6smfTyLv5/Hn4vTZ6q6lkOrfvEhhOAAAAAAoMmSxZ4AAAAAgJWJxQYAAACAKFhsAAAAAIiCxQYAAACAKFhsAAAAAIiCxQYAAACAKFhsAAAAAIiCxQYAAACAKCpFN3x/5+dlnk9PN20y0P6U72rKODtrn5F5qNebMj5szTqGzjn3wau/LvP60MmmfQa0Zh3HHem9+h/4b6xG18xzcUdyT9PGQjmci8tfs47hB/oekHl27lxTxoet6DHklw0AAAAAUbDYAAAAABAFiw0AAAAAUbDYAAAAABAFiw0AAAAAURRuozr4g5tlfsMPz8q8PnhsQRNCPBc+tl3mqx47IPNsYiLmdLBAjzz7sMx33nOfzP3TA/EmgwV57cvvlHnfz/bIPMzOxpwOFujIr26V+bYvHpJ5PjUVczpYAJ+mMqelcfk4+dO1Mt/4zU6ZZ4ePxpwOBH7ZAAAAABAFiw0AAAAAUbDYAAAAABAFiw0AAAAAUbDYAAAAABBF4Taqvqe8zB956ncyv+sL98u89oe/F/1INFnnQwMy9709Op+eljktHYvrlh88IPO+oJtuko4OmdOMs3je9KPdMk9WrZJ5RhvVkrT1vn36H27YovOXDuo8hOZMCKWlV+kmo/oZ3bTJsVp6Nt4/rP+hW7dR+WpN5mF+rllTwv/DLxsAAAAAomCxAQAAACAKFhsAAAAAomCxAQAAACAKFhsAAAAAoijcRtX75AmZ/+f9unWq3qHXMW09uvkoGx0tOhUsUJjXLVJW60Zlw3qZZ8b2tFRdHht+tlfmIx99q8x75jbLPNk/KPPcaCFDfNnEhMzTNb16+5HzMaeDS/Cpvs+F/YdlPvrwVpmvufdVmdMYF192Xj97jH3uHTLv3fW8zPOZmabNCeWEyUmZ6w5V5/I7bpR5OvCK3p7z8A3jlw0AAAAAUbDYAAAAABAFiw0AAAAAUbDYAAAAABAFiw0AAAAAURRuo6qf0m0ZLad1M1FLyGWeedY3i6Wyrk/m+di4zM//xyaZP/PgIzLfec99MvdPD1xybijOaixa/avnZO472mUesqxpc0JcVutUSrvforIaiHy1JvPej+tWx8Hv3ibzLd+j+Si2MDsr87VPnpT5kV9uk/mWB/QzktkYF8KlJ4dCgrEv8+FhmddveYvMT379Fplv/sVxPc7JUwVmB+f4ZQMAAABAJCw2AAAAAETBYgMAAABAFCw2AAAAAETBYgMAAABAFIXbqFySyjjt6Za5r1aNT9QfmY+O6Xx6Wo9Dk0Np2dnXZG61EnX/zz9kfvcf3yPz9OIhmeteMjRdro9jPjl5mSeCBfNexxV9PQ1zczJPV62SudVkhuYK9XmZ+5rRUrVP38/8Ft2a4w68Ynww98WyfEuLzPNzIzLv/75+5sn71+nxjbbHUK8XmB2KCLdeJ/PKcf3MM9Oqn2e37hiU+bHpLTLf+HP9fEobYCN+2QAAAAAQBYsNAAAAAFGw2AAAAAAQBYsNAAAAAFGw2AAAAAAQReE2Kp/qt/dd31oZhzndxhFadfNDkup1T73/WplXnz8ic9pWbN5oAgt5uQaTfOKC/oege6fSbbrJIT9xSg8zO1tqPlcaq2koN/ab37ZZ5/O6DaW+pkPm1RPDMs/OnJU5bSsLYLUJJbqlKp+aMrbX1+vK5qtlXj92otx88Pq8vp8lV2+Uec9juskvG9VNRkcevFPm274zIPN8ZkbmsJ9t/Po+mSenz8s8GPt48sPbZd7x6IAeh/tfaenLx2WeXdTHpPXRczKvP9Up802devy5m/plXhnQ974ruRmSXzYAAAAARMFiAwAAAEAULDYAAAAARMFiAwAAAEAULDYAAAAARFG4jSpd2yvz4e1rZN42YryNX9WtKpUp3YBz9g7dXrW263qZt/9lX+NnWo0tVxqrdaOqG2e818cqZLp1yhp/fn233ry7XX/uS680fiYNHf9mNcMZQlVvH1p0frGvVeaHP7VJ5pse3yDzjidebshoi1uY0t//PJOx1TplNfLQKPb6rIY/39Ym86nr9P2yc0Af32RqWuZ/+uSDMh//eFXm/3X7BxuybES3Kl1pgtHK50fGZF4f07l1DnUdHJX58Kdvk/maXS/IPJ/W3wXYfK2mc+NY5VMXZZ606OfQqQ06r6y5Qeadf75y74n8sgEAAAAgChYbAAAAAKJgsQEAAAAgChYbAAAAAKIo/IJ4/fQZmffuGpN5brzQaL1oE4J+Sbl/X4/efsZ4YbJNvNxq/CfrrZcoV6qyL8rrI1Je8tcXS43vE/1iOv4lM15QdN74/w5eaHwpzTlnfv879upz9PondYmD612tc/USXmK83H6FnYulGWUNzrhulhVyPU5l3ZsbsvqZs1HnspxYL9CHyUmZd+w+LPP66LjMfVXfor/8iS/JPD2tX/o++N23NGTXfntAbpvPGPfLFSrMz8k8v2D9D4zvuXH9DUOnZX6V8TJyfm2/Hn7vocaxKXBwzjmXX9DPNtZ1zRR0+U1+fkzmPU8N6WHadclK6F/fkCWHjO/fCjsP+WUDAAAAQBQsNgAAAABEwWIDAAAAQBQsNgAAAABEwWIDAAAAQBSF26iSri79D9ds0gOfGZF5mNYNDFbDQ6gbLTVZ8faadE2vzPPRUeMzV2bDg6/WZG61cXirOcxoGrOknbrFyNrPvr2tMWvV7Q6Z0YyzUo+hc84lbY37xznnXK6bNHxNH3dXq+rtO9plHlr19+HiZt0Yd+4TjU1G657W53/ln41NK86Vb1BbsaymMaePubm91foVdJ6PjjVkaa8+3tmIbkK6ElnXWrdW34v8+ITMrfZGd1xf9zLjntb/0LqG7MQ3bpPbbvrhHpmXve4vG0ZDXtp3lczVOeGcc0lXp95+TDeN5cP6fMn7Vst84t7bG7LVvxnQY6ywJqNLMe9xc/rZJuleJXOz1cr47gdjP3vjeXZufXdDlr37Jrlt6+6DMs+Npruljl82AAAAAETBYgMAAABAFCw2AAAAAETBYgMAAABAFCw2AAAAAERRuI0qXNQtMv7IkMzz+Xk9TtmWoJLjqAYlb4399utlnBw4KvPl3owT6npfOq/3UJhvTqNTPj2tx891Y4NXTWPjuoHB37hV54eO6bmsgJYOa3+ayv7NVquQ0XDUckxfAzY+3ngcrRaQYLXLGd9Nq71uxQpG65S5H6yWKvNqqEeZE9eMGeP78Y636fy5fcbgxRsFlxur4S8fPKG3N77/mdGO4yZ0e5V1fGvPHGjINv5Z39OnPnaHzDseMlqqlnvzn/E9rJ88VW6YZj0fPPeSjFc9Jz6z5Pm8UuUzRlOacd3MjfY38z5kfa71XJLq70JVNJnVOnRbZ/2mLTJPXzys57LEn0/5ZQMAAABAFCw2AAAAAETBYgMAAABAFCw2AAAAAETBYgMAAABAFIXbqKwmmqSjXeb5hH5L3xrHag0ImdGqYlDNGL6q/8z03Lgeo13/Te6i0eqzXFpVyjb4hOb8XWXbSsKs+FyrdeOgbg5LOnXDg1PtOs4tn2PonL0vjHPLJ+W2Nxnj+FpN5+1thTLnnJt9+2aZtx4dkXk29KrMrRYg/B/rGmB9p0qcF37Py/oftt+op7Jn/xv+zBUjdquYapM0zv/Ox/VxGbvndpl37/qHzJd7S5VqtnTOuTCnrzE+TfX2ZfdDosdR0qvWyHxk5zUy7931vMxXQkujZJ1XxrFyJduorIbPkBW/F1sNWD6sk/nYR26Wec9jh2SeWe2Slxm/bAAAAACIgsUGAAAAgChYbAAAAACIgsUGAAAAgChYbAAAAACIonAblU+NdUmrbmxwU9M6t972z43xrSYdY3vZCGG1RBhzt3o+0l7dmJMfG9Ljz84aIy0Sq8GkbENN2Varsko0rXhjW6shaW7HrTJv3X1Q5vmk0aq2iKy/rWyThn1uGcfXyM1jIM6vUNHnYqIayJxzUz/WU5n47XaZv/k3R2SenX1ND7RcmM1hVltRk7YXjXS+om8bSVurHmPwlIwfPblH5ne/7b0yz4Z1M9mSZJ0TRjOi1WpTujGuDKP1y2qY7HxV38/+cEK3Ud1983tkvlTacS7Fuq6Zd7+SDUdme5V1/RWNnWF8Qm7aNaSP1e8H/ybzD73zwzKvG61/K7Yxrux103oWMpo8g2s85t7pbStDwzKfele/zLNf6maytd9aq7ffr9urYuGXDQAAAABRsNgAAAAAEAWLDQAAAABRsNgAAAAAEAWLDQAAAABRFG6jyueMtoxzRkOI2TpVvGnhX4yGB2v7XDQ2GHP3Y7rJwWyRGi3X0oMFKtF2ZX0vw/lRmbc9o1vSMqs9bQkq3XJmtXtZ52jJBpzcmI8/P1Z4jKqxbfUrPTJvHz2s5zKqj/uyV7b9xWhDacb2oV6XeTahr6eW92/QzXAuLKPWKYtxDQtlG+PM8a37ZXFWq1g+Ni7z6l59rf3Ahz4r8zCyb2ETu9ys1imzpbFEE+brjVOSr1QbMuv+V/27blfc+cnP67FPvKg/NHbzZJN4o1lRtT8tZBzrOdQ8n0vsN2uMfEI3YW586Kze/ok2Pf7xo4XnEhO/bAAAAACIgsUGAAAAgChYbAAAAACIgsUGAAAAgChYbAAAAACIonAbldl+Ybx1b7ZXlW1VKfm2v3yz32qjmpsr95lG24SvNbZEOOdc0tmhhx83WlvK7puyyjZLLIcmCmOfhVmdZ9YxN6Sru/U4ExdKzaeprHYpq0XKOnfLbm+w2rFKtWYZf1NqnIsh03PM77xJ5tVT52WenTqjx58v9z3BApS8viRdXTLPJ3Vry1IUrOuPtS/KtoqVmYt1bhltY846n43mP+ucrmy+Wub1o8f1OLHvQ9b4JVsmzWYi63ptse4h6vnD2Da/OCPzyv5jenvRdOWcc9mdN+qpPLtf5ot13Szd8mZ995vVLGodc3VvNe7D5nXNaM70Vf0477s6dX7DZp3vH9TzmX5jjZ38sgEAAAAgChYbAAAAAKJgsQEAAAAgChYbAAAAAKJgsQEAAAAgisJtVGlvj8yn77xG5u3PHpF5fmGq6Ec655zzFT1FqzFDNUD5tja57ezWPpnXzuoWgPrqdpmPXafzZF43G7QN67m37j4o86ZJdJuW1Whh7nuzdaM57UayHaRJDUzebBSr6WH6N8j8wrWrZN792AE9nyZKWlpkbrbIeN00YgnzxvE1vj8+1cdGfU+STt2MEWZ0043v1vs579X5+BZ9rv/kv3fJ/FO//prMt/54SOZYALOZxWh+sa5T87pVMLvrNpmnT7xwqZldfkup4W+R2gnrg8dk7qvGNXiRGo58q77OOuNalbS1ytxqQDTvr0YjkpqPdS9Oe1frsY3nL+tvnXmTzr+1f6/Mf3LXXTKvn3pV5s3ijTYta/8k7fqZzWyLS/RzRpjX91zzGUk8a/mKvt4F6xnGaJ2y2tOs79mhr+rzbfB9u2W+49779OcWxC8bAAAAAKJgsQEAAAAgChYbAAAAAKJgsQEAAAAgChYbAAAAAKLwISylegwAAAAAKwW/bAAAAACIgsUGAAAAgChYbAAAAACIgsUGAAAAgChYbAAAAACIgsUGAAAAgChYbAAAAACIgsUGAAAAgChYbAAAAACI4n8BvWVfCflNmgIAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1000x1000 with 7 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "attn_mat = model._model.backbone.layers[selected_layer].mixer.attn_mat\n",
    "fig, axs = plt.subplots(1, len(selected_chan), figsize=(10,10))\n",
    "for i,c in enumerate(selected_chan):\n",
    "    curr_attn_mat = normalize_attn_mat(attn_mat[0,c,:,:].abs())\n",
    "    axs[i].imshow(curr_attn_mat.cpu().detach().numpy())\n",
    "    axs[i].axis('off')\n",
    "model._model.backbone.layers[selected_layer].mixer.compute_attn_matrix = False"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "def save_attention_matrix(attn_matrix, channel_index):\n",
    "    plt.figure(figsize=(6, 6))  # Create a new figure for the matrix\n",
    "    plt.imshow(attn_matrix.cpu().detach().numpy(), cmap='viridis')  # Display the matrix using a color map\n",
    "    plt.axis('off')  # Hide the axes\n",
    "    #plt.colorbar()  # Optionally add a colorbar to indicate the scale\n",
    "    filepath = f'MAMBA_attention_map_layer_{selected_layer}_channel_{channel_index}.png'  # Name the file based on the channel index\n",
    "    plt.savefig(filepath, dpi=300, bbox_inches='tight')  # Save the figure to a file\n",
    "    plt.close()  # Close the figure to free up memory\n",
    "\n",
    "for c in range(100):\n",
    "    curr_attn_mat = normalize_attn_mat(attn_mat[0, c, :, :].abs())\n",
    "    save_attention_matrix(curr_attn_mat, c)  #"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Extraction of Old Attention Maps:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1000x1000 with 7 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "model._model.backbone.layers[selected_layer].mixer.compute_attn_matrix = True\n",
    "model._model.backbone.layers[selected_layer].mixer.old_attention = True\n",
    "model._model = model._model.cuda()\n",
    "out = model._model(input_tensor)\n",
    "attn_mat = model._model.backbone.layers[selected_layer].mixer.attn_mat\n",
    "fig, axs = plt.subplots(1, len(selected_chan), figsize=(10,10))\n",
    "for i,c in enumerate(selected_chan):\n",
    "    curr_attn_mat = normalize_attn_mat(attn_mat[0,c,:,:].abs())\n",
    "    axs[i].imshow(curr_attn_mat.cpu().detach().numpy())\n",
    "    axs[i].axis('off')\n",
    "model._model.backbone.layers[selected_layer].mixer.compute_attn_matrix = False\n",
    "model._model.backbone.layers[selected_layer].mixer.old_attention = False"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Extraction of Attention Vecotrs (New Method):"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABAMAAAAbCAYAAAAJdEbLAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8fJSN1AAAACXBIWXMAAA9hAAAPYQGoP6dpAAADEklEQVR4nO3dz4tWVRgH8HPvdQaddPwxQwQTA4HQYkjXbv2RorjpF7Qww5VB0L5o1U6ihSDqQjcuBP8AG1A3Lmrjop1FMFEUQQkzodn8eu/pD4jzXOkdEjqfz/Y7z70v7z3znPM+vPA2OeecAAAAgGq0z/sFAAAAAP8twwAAAACojGEAAAAAVMYwAAAAACpjGAAAAACVMQwAAACAyhgGAAAAQGUMAwAAAKAy2571D08sfBzm7eUnxaz/YGdYO3r4/bO+jH/o9u6Nr72yEtfvf6WYrc3H1/7xXB/mu+9vD/PlhXL90ltXw9pv1tbC/MPv3i1m02fLzyqllBZ/vRTm4zo+dSbM+9XVYtbN7Atr859P45u35flX3tiMawfkzY1i1kxOhrVN18XXHo3CvJ2aKocze8Labz96McyX3iyvxeNvvBfW3vnq0zDfCoPraT14Lm0TX7yJ56V5Yz2oHe/aqS8/83bXrrA0r8b9oZt7KcxHs9PF7NHB+N4PPrsc5vtvni9mr178Jaz98ocvwnxcx9q3/3Vtsy3eTof+h8P1kOO9Zpy11EzEvSnqayml1A2sxf5puSeHfSullF6O1+ntu7eK2ckDR8Laxd+uxPfeAoPrKegRQ+9N9L6mFO8pY63FlML12O7YEdcOaKbi+v6Px+V779kd1q4dmA/zezeuFbOTrx0Oaxd/j89s4xpaS910uWf3f5XPVCml1O58IcxHy8vl2u3xObcfOKtG/WP0uPysU0qpm50N8zxQnyYmitHK6YWw9OvP4/5x6tDpYrb5089h7Z1Rua9tldcny58RUop7xFDPz+vBuWhAHsV73WDviva6MffooXN86nMx6mbiz5MPL8yF+dLR68Xs2Dvvh7X37n8S5in5ZgAAAABUxzAAAAAAKmMYAAAAAJUxDAAAAIDKGAYAAABAZQwDAAAAoDKGAQAAAFCZJudc/mFEAAAA4H/HNwMAAACgMoYBAAAAUBnDAAAAAKiMYQAAAABUxjAAAAAAKmMYAAAAAJUxDAAAAIDKGAYAAABAZQwDAAAAoDJ/A1nYpS+bG0I0AAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 1300x700 with 7 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "model._model.backbone.layers[selected_layer].mixer.compute_attn_matrix = False\n",
    "model._model.backbone.layers[selected_layer].mixer.old_attention = False\n",
    "model._model.backbone.layers[selected_layer].mixer.compute_attn_vector = True\n",
    "model._model = model._model.cuda()\n",
    "out = model._model(input_tensor)\n",
    "attn_vec = model._model.backbone.layers[selected_layer].mixer.attn_vec\n",
    "fig, axs = plt.subplots(1, len(selected_chan), figsize=(13,len(selected_chan)))\n",
    "for i,c in enumerate(selected_chan):\n",
    "    curr_attn_vec = normalize_attn_mat(attn_vec[0,c,:].abs())\n",
    "    axs[i].imshow(curr_attn_vec.unsqueeze(0).cpu().detach().numpy())\n",
    "    axs[i].axis('off')\n",
    "model._model.backbone.layers[selected_layer].mixer.compute_attn_matrix = False\n",
    "model._model.backbone.layers[selected_layer].mixer.old_attention = False\n",
    "model._model.backbone.layers[selected_layer].mixer.compute_attn_vector = False"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Extraction of Attention Vecotrs (Old Method):"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABAMAAAAbCAYAAAAJdEbLAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8fJSN1AAAACXBIWXMAAA9hAAAPYQGoP6dpAAADCUlEQVR4nO3dv2teVRgH8OfeN0mTJqWhFa2lS0FwqRiwoouOtZ0cnJ3r0qV17CCuOktBcRE6uBWqFOnQzSGbUkVEUUudlLShP/Lrvde/4DynNDaFns9n/eY59+XmueeePLyQbhzHMQAAAIBm9E/7AwAAAAB7yzAAAAAAGmMYAAAAAI0xDAAAAIDGGAYAAABAYwwDAAAAoDGGAQAAANAYwwAAAABozMyj/uCp1z5K8/63W8Xs65++S2vfO/Zmmk+eO1wOt7bT2jh2JI3H3/8qZv2LL6S1w8HFND96qbx2RMTtc8eL2d9vH0hrf7jwWZrf3HpYzK6sr6S1F09cTfPdOv3KxTSf3vzlsdeeHD6Ur712t5j1c7Np7VDpta7vitk4jGlt7doxW8kT3SSf+Y3bO2n+x4evFrOfz+Z92B/5Nc3/D6fe+DjNx9Ufi9lk+WC+eOX3Nl1fL2bdTL69jjv5fU/rJ5N87a2tNJ8sL6f5dG2tXPtSed+KiIhKL6+tlJ/R7z+9lNY+6X56Z//7aT5sbDz22tV+mE6T4srcfhwqF0/qh+S6EdHNzuWX3sn3xX5pqVy7sZmvnd2TiJhJ3tHfrH6bf6492JtOP/9Bmk//+bccduX3SUREv7CQ5sPD8hmgq+0flfu+m37q5+fztfu817uFcn32fo+I6JPaiIjt118uZtcvf5mv/YT76a13P0nz+aur5XCsnD8W87PsuFl+TvulvHZ6t/yOjIjo9+0rZrUzV7+4P82H+w/SfHJouVx7J++l6p68Uu6la1e+Skv3Ym86c/x8mu/8Wf6brro3JXt+RMRw71556bnK+6Zytsn2tl2fw2uyc/p23stD8oxFRGyeOVnMbnzxeVr7KP3kmwEAAADQGMMAAAAAaIxhAAAAADTGMAAAAAAaYxgAAAAAjTEMAAAAgMYYBgAAAEBjunGs/ANSAAAA4JnimwEAAADQGMMAAAAAaIxhAAAAADTGMAAAAAAaYxgAAAAAjTEMAAAAgMYYBgAAAEBjDAMAAACgMYYBAAAA0Jj/ANraoS+rBR0bAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 1300x700 with 7 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "model._model.backbone.layers[selected_layer].mixer.compute_attn_matrix = False\n",
    "model._model.backbone.layers[selected_layer].mixer.old_attention = True\n",
    "model._model.backbone.layers[selected_layer].mixer.compute_attn_vector = True\n",
    "model._model = model._model.cuda()\n",
    "out = model._model(input_tensor)\n",
    "attn_vec = model._model.backbone.layers[selected_layer].mixer.attn_vec\n",
    "fig, axs = plt.subplots(1, len(selected_chan), figsize=(13,len(selected_chan)))\n",
    "for i,c in enumerate(selected_chan):\n",
    "    curr_attn_vec = normalize_attn_mat(attn_vec[0,c,:].abs())\n",
    "    axs[i].imshow(curr_attn_vec.unsqueeze(0).cpu().detach().numpy())\n",
    "    axs[i].axis('off')\n",
    "model._model.backbone.layers[selected_layer].mixer.compute_attn_matrix = False\n",
    "model._model.backbone.layers[selected_layer].mixer.old_attention = False\n",
    "model._model.backbone.layers[selected_layer].mixer.compute_attn_vector = False"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Ablations visualization:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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YQ7n/jt7371nzx4ZM2aMhIaGisPhkK5du3o9/1Smrq7NcocPHxaLxSL/+te/5LvvvhMAsnnz5kqfq0WLFkm3bt3E399f6tWrJ7GxsfLFF1+IiGg/x9amWvnNRlRUFH744Qfs2rXrvG12796N9PR0dO7cGRMnToTT6YTT6UTnzp2xfv36Su+TmJiI0aNHw26345ZbbkFaWhq2bt3qiffp0wcPPvggAOCJJ57AokWLsGjRIrRr1w5z585FkyZN0LZtW8/t5UfcCgoK0LdvXyxevBh33nknXn/9dcTExGDatGl45JFHKsxjyZIlePnllzFp0iQ8++yzOHToEEaPHo2SkhIAwKRJkzBo0CAA8Iy1aNGi8z4XP/30E2JjY5GamorHHnsMTz31FA4ePIh+/frhu+++q9B+ypQpSE1NxfTp03Hffffh008/xeTJk8/bPxk3adIkPPHEEwCABx980GudVGbTpk24//77cfPNN+Oll17CmTNnMGbMGOTk5HjabN26FcnJybj55pvx+uuv495778XatWvRr18/FBQUGJrX6NGjYbFYkJSU5LltyZIlaNu2La699toK7X/55Rd8/PHHiI+Px9///ndMnToVO3fuRN++fZGeng4AaNeuHWbOnAkAmDhxomed9unTx9Cc6A8dO3ZEvXr18M0333hu27hxI6xWK1JTU3Hy5EkAgNvtRnJycqXPsZHXIzc3F0OGDMGf/vQnvPLKK2jbti3+93//F59//rmnTWFhIfr164dFixbhtttuw8svv4yQkBAkJCTgtddeq/JjU23PPvnkEwBlR5aNWLNmDeLi4pCVlYUZM2bgkUceQXJyMmJiYir9nd24ceOQn5+P559/HuPGjcP777+PZ555xhMfP348vvnmG2RkZHjdb9OmTUhPT8fNN99c5cd7uaqra/DTTz8FANx+++2G+zt58iTeffdd9OvXDy+++CJmzJiB7OxsxMXFeX4PEB4ejn/+858AgFGjRnnGLD9z8tNPP+H666/Hnj178Pjjj+OVV16B0+nEyJEj8dFHH1X5MV7J6uraLLd06VI4nU7Ex8eje/fuaNmyJRITEyv09cwzz+COO+6Ar68vZs6ciWeeeQZNmzbFunXrAED5ObbW1UaG8+WXX4rNZhObzSY9e/aUxx57TL744gspLi72tElKShIA0qBBA2nVqpUsXLhQFi5cKK1atRK73S6pqalefZZnwV999ZWIiLjdbmnSpIk89NBDXu0u5Dcbs2bNEqfTKfv27fO6/fHHHxebzSa//vqriPyR0TZo0EBOnDjhabd69WoBIJ9++qnnNtV3+HDO0ZGRI0eK3W6XAwcOeG5LT0+XoKAg6dOnj+e28jMbAwcOFLfb7bn9r3/9q9hsNsnLy6t0PKqa8iMaK1as8Nx2vjMbdrtd9u/f77mt/AjOvHnzPLcVFBRUGCMlJUUAyIcfflhh3MrObIiIjB07Vm644QYRKTtyGxkZKc8884zXGbdyZ86c8TorJ1K2fh0Oh9d3l/mbjeozbNgwzxE5EZHRo0fL6NGjxWazec52bdu2zesI39lH7kT030k+d80UFRVJZGSk1xH8uXPnCgBZvHix57bi4mLp2bOnBAYGysmTJ0XE+JE7kfNvz0aNGiUAvM64qXTp0kUiIiIkJyfHc1tqaqpYrVa58847PbeVv9/uvvvuCuM1aNDA8/fPP/9c4f0mInL//fdLYGBgpe+9K1ldXoPn7v8KCwslOzvb8+/sNVpaWur1WwCRsm83NGzY0GvNqX6zccMNN0inTp3kzJkzntvcbrf06tWrwrcuqG6uzXKdOnWS2267zfP3E088IWFhYV6/3U1LSxOr1SqjRo2qsO8++/PepfqbjVo5szFo0CCkpKRgxIgRSE1NxUsvvYS4uDg0btzYcyTs1KlTAID8/HysXbsWCQkJSEhIwJo1ayAieOmll7z6TExMRMOGDdG/f38AZZePHT9+PJYtW3ZBV5k424oVKxAbG4vQ0FAcP37c82/gwIFwuVxe2ThQdjQtNDTU83dsbCyAsqPJVeVyufDll19i5MiRaNGihef2q666Crfeeis2bdrkyfrLTZw40esyrLGxsXC5XDh8+HCVx6eLM3DgQLRs2dLzd+fOnREcHOy1Fvz9/T3/LykpQU5ODqKjo1GvXj1s27bN8Fi33norNmzYgIyMDKxbtw4ZGRm49dZbK23rcDhgtZa9/V0uF3JychAYGIg2bdpUaUwyLjY2Ftu2bcPp06cBlB1dHzp0KLp06YKNGzcCKDuaZ7FY0Lt37wsaIzAw0OsIrt1uR/fu3b3W22effYbIyEjccsstntt8fX3x4IMP4tSpU/j6668vaOzKlG+bgoKCtG2PHTuGHTt2ICEhAfXr1/fc3rlzZwwaNAifffZZhfvce++9Xn/HxsYiJyfHM27r1q3RpUsXLF++3NPG5XJh5cqVGD58uNd7ry6oy2swMDDQ6/a33noL4eHhnn9nP16bzeb5PYDb7caJEydQWlqK6667ztD28cSJE1i3bp3nzFv5Z4acnBzExcUhLS0Nv/32W7U9xitBXVybAPDjjz9i586dXuPdcsstOH78OL744gvPbR9//DHcbjeefvppz767nNmX3a8OtXbp227duiEpKQm5ubnYsmULpk2bhvz8fIwdOxa7d+/27ARiYmLQtGlTz/2aNWuG3r17Izk52XOby+XCsmXL0L9/fxw8eBD79+/H/v370aNHD2RmZmLt2rUXNde0tDT897//9dowhYeHY+DAgQC8f9RePsezlSceubm5VR47OzsbBQUFaNOmTYVYu3bt4Ha7ceTIEdPGp4tz7msBlL0eZ78WhYWFePrpp9G0aVM4HA6EhYUhPDwceXl5+P333w2PNXToUAQFBWH58uVITExEt27dEB0dXWlbt9uNV199Fa1atfIa88cff6zSmGRcbGwsSktLkZKSgp9//hlZWVmIjY1Fnz59vHam7du39/qwXRVNmjSpsOM5d70dPnwYrVq1qrDDateunSdeXYKDgwGUHTTSKR/3fNu648ePez6IlDOyrRs/fjw2b97s+XC3YcMGZGVlYfz48VV4JFeGurgGyxPd8gOY5caMGYOvvvoKX331FTp37lzhfh988AE6d+4MPz8/NGjQAOHh4fjPf/5jaPu4f/9+iAieeuqpCp8byi9ac+7nhrquLq5NoOyH4U6nEy1atPB8dvXz80Pz5s29vkp14MABWK1WtG/fvlrHrym1c/mcs9jtdnTr1g3dunVD69atcdddd2HFihWe77g1bNiwwn0iIiKwfft2z9/r1q3DsWPHsGzZMixbtqxC+8TERAwePPiC5+h2uzFo0CA89thjlcZbt27t9bfNZqu0nYhc8ByqorbHpz8YeS2mTJmChQsX4uGHH0bPnj0REhICi8WCm2++GW632/BYDocDo0ePxgcffIBffvlFeV3v2bNn46mnnsLdd9+NWbNmoX79+rBarXj44YerNCYZd91118HPzw/ffPMNmjVrhoiICLRu3RqxsbF48803UVRUhI0bN2LUqFEXPEZ1vvfPd7SsKmeK27ZtC6CsrlL5Gd7qZOTxjh8/HtOmTcOKFSvw8MMP41//+hdCQkIwZMiQap/Ppa4ur8Fdu3YhJibGc3vTpk09BzLLv7VQbvHixUhISMDIkSMxdepUREREwGaz4fnnn8eBAwe0Y5ZvQx999FHExcVV2uZ8B4Lqqrq4NkUES5cuxenTpytNIrKysnDq1KkKZ+UuR7WebJztuuuuA1B2Or1Tp07w9fWt9FRjeno6wsPDPX8nJiYiIiICb7zxRoW2SUlJ+Oijj/DWW2/B399febrpfLGWLVvi1KlTnjMZ1cHoaa/w8HAEBARUelm+vXv3wmq1ep35ocvPypUrMWHCBLzyyiue286cOYO8vLwq93XrrbdiwYIFsFqtyh+/rly5Ev3798d7773ndXteXh7CwsI8f18Op2cvF+Wn7Ddu3IhmzZp5PnzHxsaiqKgIiYmJyMzMVP4Avzpej6ioKPz4449wu91eR+/27t3riQN/nCU4dx1WdmTvfPMaPnw4nn/+eSxevFibbJSPe75tXVhYGJxOp7KPylx99dXo3r07li9fjsmTJyMpKQkjR46Ew+Gocl+Xu7q4BuPj4/HCCy8gMTHRK9lQWblyJVq0aIGkpCSvfs+9lP75xiz/yrOvr2+1fm64ktXFtfn111/j6NGjmDlzpufMSbnc3FxMnDgRH3/8MW6//Xa0bNkSbrcbu3fvRpcuXc47/0t1n10rX6Nav359pZlk+Xdy27Rpg6CgIAwdOhTJycmeFxkA9uzZg+TkZM+Zj8LCQiQlJSE+Ph5jx46t8G/y5MnIz8/3/BakfGdV2Qc5p9NZ6e3jxo1DSkqK1/fnyuXl5aG0tLTKz4FqHmez2WwYPHgwVq9e7XU1lszMTCxZsgS9e/f2fFWBLk82m63C+2HevHkX9Fuj/v37Y9asWfjHP/6ByMjIKo25YsWKCsm90XVKxsTGxuK7777D+vXrPTvTsLAwtGvXDi+++KKnzflUx+sxdOhQZGRkeP2OobS0FPPmzUNgYCD69u0LoGynarPZKvwm7c033zQ8r549e2LIkCF499138fHHH1e4X3FxMR599FEAZb9D69KlCz744AOvfnbt2oUvv/wSQ4cOvZCHC6Ds7Ma3336LBQsW4Pjx43XyK1Tl6toajImJwaBBg/D2229j9erVlc7n3G1h+RHws2//7rvvkJKS4tUuICCg0jEjIiLQr18/zJ8/H8eOHaswXnZ2dqXzqOvq2tos/wrV1KlTK3x2veeee9CqVSvPV6lGjhwJq9WKmTNnVvj2wdnr9HyfY2tbrZzZmDJlCgoKCjBq1Ci0bdsWxcXFSE5OxvLly9G8eXPcddddAMq+6rF27VoMGDDAc8na119/HfXr1/dcfvSTTz5Bfn4+RowYUelY119/PcLDw5GYmIjx48ejS5cusNlsePHFF/H777/D4XBgwIABiIiIQNeuXfHPf/4Tzz77LKKjoxEREYEBAwZg6tSp+OSTTxAfH4+EhAR07doVp0+fxs6dO7Fy5UocOnTI62iwEV27dgVQdvnUuLg42Gy28x6JfvbZZ/HVV1+hd+/euP/+++Hj44P58+ejqKiowg/l6fITHx+PRYsWISQkBO3bt0dKSgrWrFmDBg0aVLkvq9WK//u//zM05syZM3HXXXehV69e2LlzJxITE70uQgCUndWrV68e3nrrLQQFBcHpdKJHjx64+uqrqzw3KttRPvfcczhy5IjXTrNPnz6YP38+mjdvjiZNmpz3/tXxekycOBHz589HQkICfvjhBzRv3hwrV67E5s2bMXfuXM933ENCQnDTTTdh3rx5sFgsaNmyJf79739X+l1z1fbsww8/xODBgzF69GgMHz4cN9xwA5xOJ9LS0rBs2TIcO3YMc+bMAQC8/PLLuPHGG9GzZ0/85S9/QWFhIebNm4eQkBDl1wJ1xo0bh0cffRSPPvoo6tevX6ePNtfFNbh48WIMGTIEI0eOxI033oiBAwciNDQUGRkZWLNmDb755hvceOONnr7i4+ORlJSEUaNGYdiwYTh48CDeeusttG/f3uu3H/7+/mjfvj2WL1+O1q1bo379+ujYsSM6duyIN954A71790anTp1wzz33oEWLFsjMzERKSgqOHj2K1NRUw89XXVGX1uaoUaOwatUqDBo06LyFnEeMGIHXXnsNWVlZiI6OxpNPPolZs2YhNjYWo0ePhsPhwNatW9GoUSM8//zznrEq+xxb62r+Algin3/+udx9993Stm1bCQwMFLvdLtHR0TJlyhTJzMz0avvDDz/IwIEDPYXH/vznP3tdgnb48OHi5+enLPiXkJAgvr6+cvz4cREReeedd6RFixZis9m8Ll2WkZEhw4YNk6CgoArFUPLz82XatGkSHR0tdrtdwsLCpFevXjJnzhzPJXsru8RoOZxzebzS0lKZMmWKhIeHi8Vi8bos2rltRcou+RYXFyeBgYESEBAg/fv3l+TkZK825Ze+3bp1q9ft57tEG12Yqlz69oEHHqhw/6ioKJkwYYLn79zcXLnrrrskLCxMAgMDJS4uTvbu3Vuhne7St+dzvkvf/u1vf5OrrrpK/P39JSYmRlJSUipcSlCk7NLN7du3Fx8fH14G9yKdPHlSbDabBAUFSWlpqef2xYsXCwC54447vNpX5fUoL1p1rgkTJkhUVJTXbZmZmZ41Z7fbpVOnTpW+rtnZ2TJmzBgJCAiQ0NBQmTRpkuzatavCOlBtz0TKLu88Z84c6datm2eb36pVK5kyZYrXpaFFRNasWSMxMTHi7+8vwcHBMnz48PMW9cvOzva6vXwbeG5BTBGRmJgYASD/8z//UyFWl9TVNVhYWChz586Vnj17SnBwsPj4+EhkZKTEx8dLYmKi13Phdrtl9uzZEhUVJQ6HQ6655hr597//XenjSE5Olq5du4rdbq+w7z5w4IDceeedEhkZKb6+vtK4cWOJj4+XlStXVnicVLfWZnmx3ffee++8z8eGDRsEgLz22mue2xYsWCDXXHONOBwOCQ0Nlb59+3pKPoioP8fWJosIfzVMRERERETVr9YufUtERERERFc2JhtERERERGQKJhtERERERGQKJhtERERERGQKJhtERERERGQKJhtERERERGQKw0X9WiydrYy3vG37RU+GLj9fuVfUyDhD2j6ujLv2HaiRedClpabWHwC0eu7vynjzp1KUcboy1dQaHNxthjIuP/xUI/OgSwv3wVSbjK4/ntkgIiIiIiJTMNkgIiIiIiJTMNkgIiIiIiJTMNkgIiIiIiJTMNkgIiIiIiJTMNkgIiIiIiJTMNkgIiIiIiJTWEREjDTc8WtTZbyz3U/bR1yjLoYmRZePmrrGtzujlTLe5/6J2j78P95SXdOhS0RN1tk4cOQqZfxq30BtH9wGXnm4DaTadKmsv9gHJmn7CPjou+qaDl0iWGeDiIiIiIhqFZMNIiIiIiIyBZMNIiIiIiIyBZMNIiIiIiIyBZMNIiIiIiIyBZMNIiIiIiIyBZMNIiIiIiIyBZMNIiIiIiIyhY/Rho/feIcyLod/0/ZRNKyDMu74z1aj06E6Zug1g5XxgGaF2j6soaHKuCs3t0pzorplcv/blXF3eoa2D1f/9sq4bf22Ks2J6o5h3YYq447oEm0ftvBwZdyVnV2lOVHdodsHO5ue1vbBfXDdxTMbRERERERkCiYbRERERERkCiYbRERERERkCiYbRERERERkCiYbRERERERkCiYbRERERERkCiYbRERERERkCsN1Nn4dob4+d5NXDmr78PtiuzJu/zpSGS/qq7+OPV2ZLHa7Mm49pF8be59trYxHJ55RzyE5VTsGXbmO/rmRMn7VvKPaPnw2/qiMl6xppr7/wF+1Y9AVyle9u/bdq691tecl9fqKXtBEGbduVO/D6cpl8fVVxq2Hjmn7+PnpNsp49PICdQffqrefdOnimQ0iIiIiIjIFkw0iIiIiIjIFkw0iIiIiIjIFkw0iIiIiIjIFkw0iIiIiIjIFkw0iIiIiIjIFkw0iIiIiIjKF4Tob9feWKuNSqo4bcXpmY2U8fYW61gcANLtp50XPgy497hO56nihukYGALR9PUQZz+mhXl9hvzXVjlF6+Ii2DV2eGn9xXBl3VcM20HGfepN8bHIvbR8R/0i+6HnQpUc02zh33u/aPpqtaq6MH75fvYabu7tox7Bs3qFtQ5cf7T74TJG2jzZvZinjJ/+k3geHNFbXOgKA0t/StW2o5vHMBhERERERmYLJBhERERERmYLJBhERERERmYLJBhERERERmYLJBhERERERmYLJBhERERERmYLJBhERERERmYLJBhERERERmcJwUb8TbdVNG39q0/ZhCwlWxi0n1EWLAj9T3x8ArH9qp4y7U/do+6BLjzU4SBmXIn1BIYum6FDgb8XKuDvIqR3D6uen7uOMvvggXZry24Qq4wF7LNo+rP7+yril1KWMhxwo0Y7hc3WUMl568LC2D7oE1dPs/wwU9Qs4kq+MB6+rp4yX+qu3kQDgCFJvq9356jnQpUm7Dy7Wrw1LoXof7J+hjktggH4Mh0Pdh4HPClT9eGaDiIiIiIhMwWSDiIiIiIhMwWSDiIiIiIhMwWSDiIiIiIhMwWSDiIiIiIhMwWSDiIiIiIhMwWSDiIiIiIhMYbjOhktdPsAQ3fW1rQeOKONh7sb6Qfb/qgwffaKXtosms5P141CNkvoh6nhmtr6Pk6eUcd8TmjowLnUNBAA4+sC1yniTz49r+3Dt3qdtQzUvs4f62MzVq/XHbnTXopfcPGXcnldPO4b7+All/MCc67V9tHz0W20bqmFWdR0XI3UOrIfTlfFwzf0thfox0hM6KeONvszS9uH6eb+2DdUs7T44S79vk1OafXBuoLoDt1s7Rtbd6n1w5FoD62/fAW0bqhqe2SAiIiIiIlMw2SAiIiIiIlMw2SAiIiIiIlMw2SAiIiIiIlMw2SAiIiIiIlMw2SAiIiIiIlMw2SAiIiIiIlMw2SAiIiIiIlMYLuqnY/HVd2ULraeMl2qKwlh89LmRxapuE9BLX3gm556eyniDd1K0fVDNsoWqCw4BgCv3d2XcWtJQGRe7fo3nd1AXvTrkH6bt4+r8AmW89MhRbR9U/XxPqouqGdkGWuup16krO0c9hktf1EqnUadMbZvjE9XbwLC3uQ2saeJrU8ZtDepr+3CdyFPGrRb1Gnc79dV9C3qdVsYPROpKBwLRbxcp46WH1QWAqeYZ2gefyFX30VCzNgxsY/PaijJe4lTv5wGg2dJCZbz0N3VxTKqIZzaIiIiIiMgUTDaIiIiIiMgUTDaIiIiIiMgUTDaIiIiIiMgUTDaIiIiIiMgUTDaIiIiIiMgUTDaIiIiIiMgUhutsXL1CXZ/CVayuLwAApZlZyrjV4VDGLWn6a2u7z6ivz13vZae2D/uBX5Xx4thrlHHrxu3aMahq5JC6toS7QF2bAgAsNvV16vGL+nWXklLtGG3ebK2MWwvztX24IkOVcVu+ug9XnrqeCF2YqFXq7ZeRbaArK1sZ124D96nXKKDfBtpfUK8vAAhK02wDe3dRxq2bdmjHoCo6+Jsy7Dp1StuFxcdX3WDfIXXc5dKOcfVrbZRxa2Geto+SRuqaIT4n1Y/Vlauu50BVJ4fV66869sHuQ5rPeG51DQ0AaLNAPYblTIm2D/0+WLP+Tp7UjlHX8MwGERERERGZgskGERERERGZgskGERERERGZgskGERERERGZgskGERERERGZgskGERERERGZgskGERERERGZwnCdjaxeDZTxBnvStH3Y6quvXew+dVoZt2hHAGBVt3L56vMrKdFch1nTRcZDvbRjRL6WrG1Df7Bq1o62hgb01762+Pur5+Dvpx2jOMiujPsW62t1FNVX11o4MaGDMt74P8e0Y7j2H9S2IW8Z/cOV8fB9B7R92Bqo6we4Nddvt1j02y+LTd2mJFC/2Xdo6im4Her3W/oT+m1gk9ncBlaFNST4ovtwa2r0WOzqOhzWQH2dqmI/9fqyFhioyRWknkfW7e2U8cb/SdeP8cshbRv6Q03sg6129f7TEqDeNwJAaaC6jU+pW9tHST31vj73VvU++KovDKy/g4e1ba4kPLNBRERERESmYLJBRERERESmYLJBRERERESmYLJBRERERESmYLJBRERERESmYLJBRERERESmYLJBRERERESmYLJBRERERESmMFzUL2LVXmXcJaLtw5VzQt3Aqi4K4yrRF0SDW12Mym/HIX0Xeb8r476pRcp45Nfq+wNAbkJPZTz0/RRtH3WJ61iGMi6lBtaGZn1JYaEy7j5doB3C/uMh9Rhn1GsHAPx/Vb8tG29RHyPIG9xGO0Zoqfp9UnroV20fdU3kip+VcUPbwOM56gaaNaorygbo3wvOLYe0fbhO5Cnjjh3qwmxN1mq29QAyp6gL/zWcx6J/Z3NlZCrj1bENdBeeUd9fFwdgT1UXDJVifVE/v0PqeTbaoi7e+/sNbbVjhGg+T5QeOartoy6piX2wW7d/NLD/9PlJs/4MfI50HFHPM/IH9fo72V+//oJ1++ArbP3xzAYREREREZmCyQYREREREZmCyQYREREREZmCyQYREREREZmCyQYREREREZmCyQYREREREZmCyQYREREREZnCcJ0NS2iIukFurrYPa1CQMq67hrzFx8B0bXZlWArUtRSM0NVKsDqd2j4abM9TxtMfVl+DPnJuHbsGvU193WurgbXhLtJdo1s9hkUzBwAQTS0Ocbm1fcClvv62xa5e4yE/n9QOcbxPY2U8TFMzovTwEe0YVxpLoOZ9rasjBP22wX36tKYD/Tq3+Gq2gb/r14do1qD7lHqe1oAA7RhXrVc/XxkPqLeBEW9wG3g2q2a7AOjrGFis6voBujkAgGi2s7q1BUC/DfT3V8adR/Q1kdKHN1PGG/1X/V4r/eWQdowrikV9bNrq56ftQrsP1oxhZB+srRXj1tdDEqu6FoduHxyYZqDWWkwTZTx0k2YffPQ37RiXEp7ZICIiIiIiUzDZICIiIiIiUzDZICIiIiIiUzDZICIiIiIiUzDZICIiIiIiUzDZICIiIiIiUzDZICIiIiIiUxiusyG2i89LLHZfddxIHQ0d0dQxcOvrHIjmOsy6az3rrsEMALorPfvmq1s8kLZPO8YbrVpr21wupER93Wv4Glg7mtoR2uu/W/TX59atP93aMkQzT2uOvo5C4G/q69QfvKOpMt48SX1/AHDt1q/Ry4muhooh2jWmrnNgbP1oxtBtI4200c3Doh/Dmqtep+E71Nft3//367VjRD/yrbbNlcLQ/lN0dab0dQy0dPtYI2vYT7MP1XyWgK5eCICSYHV8yKfblfEVT8Rpx/BfvUXb5nKh3T8aeM51+2BAs/80UKJFt/kzwqJ7H+j2wZptGwA4j6n3oUfGRynjTT7V1zVx7TugbVNTeGaDiIiIiIhMwWSDiIiIiIhMwWSDiIiIiIhMwWSDiIiIiIhMwWSDiIiIiIhMwWSDiIiIiIhMwWSDiIiIiIhMwWSDiIiIiIhMYbiKnqWw6KIHc+WcuLgOrAYKDrnVxVaMFNzTFrTSFYcr1RSgA2DNylXGI5LVffwjYZx+DJ9dyriReV4qbPXrKeOG1pamYJp2bRgoRmXVzBOFZ7R9WIIClXEJdqqHaKypVgUgt41DGS8NVD9Wd4CB95Hu/ap5r15qiv7UXBn3Wadfg+7ikouag1VXzAyA+4x6jdkaN9H24TqWoe4jMkIZF4d+nkVNQ5Xx3FbqNQqrgfdjUJAy7s7P1/ZxuXCd1BcS09EWjXQVa/uwODSvm5GikroCcpr3kc9v+vdi08/VfXyyeYAyHrj3oHaMy2sLp1Yj+2AfzXbDwNqxhqq3K6LZPgKANVC9j5UgdbyoUYh2jLxozT44QH1/8b+89sE8s0FERERERKZgskFERERERKZgskFERERERKZgskFERERERKZgskFERERERKZgskFERERERKZgskFERERERKYwXGdDd31kQzTX/LX4qqcjRQZqfWjm6S4o0Pehoe3DwHPlPq3pIzNbGfbR1XMA4NJcMz3vzp7aPup9mKJtUxPceb+rG2hqnwDQrj8p1l9DXseVmXXRfUB3vfzf1GHfvfr113CD5r3o76/uQHcdfADu6zsq4z77jmr7cB3P0bapKY4ff1XGXUbWINTXidddZ15XQ6OsE/XrX3pE/7zraPswsA20/aJ+PsO+Vt+/YbC6Hg0AuE6dUsaLhnbT9uH4bKu2zSXBwHOuW19i4H2t49btpw28T7Q1oAoL1fHf9TVHLBnqbbWvbn2V6OtUFYzqoYwHf6/ZmKN63q/VoUb2waWaOkQGxnBlqz87GaGtv3NMHbal6d+LYZs0+2BdvRoD71VL1/bKuPUX/fq76Pp45WNVSy9ERERERETnYLJBRERERESmYLJBRERERESmYLJBRERERESmYLJBRERERESmYLJBRERERESmYLJBRERERESmYLJBRERERESmMFzUr6RpA2XcYqDwjE1TJMfidCrjpemaSioArJpiZO4z+sKAFqu6IIvFblfGxUCxH1ujhsp46ZF09RwC1c8VANhc6gJi2dep4wDw9xnbtG1qQnUUm4JoHq+homyXAYv+GIKuaJZoik7q3iMA4PtLhnoMA4UprQWa4l01yK0rtlgNqmedXwLr2MAcLDb1GtKtUfep01WaUmWc249o20i7Vhc9TnWw+vsp42KkqJ9m/6gtnOvW7zO0hSero/hgiboAq0/DMO0YuiJ1loAA9RyC1HEAOBqnfh/MefEbbR+v/+1mbZuawH1w9dLugzVFmY3sg62/ZqobhIbo+yg0UEjWAJ7ZICIiIiIiUzDZICIiIiIiUzDZICIiIiIiUzDZICIiIiIiUzDZICIiIiIiUzDZICIiIiIiUzDZICIiIiIiU1hE6tCFjYmIiIiIqMbwzAYREREREZmCyQYREREREZmCyQYREREREZmCyQYREREREZmCyQYREREREZmCyQYREREREZmCyQYREREREZmCyQYREREREZmCyQYREREREZni/wHxCkSic8yrDAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 1000x500 with 5 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "model._model.backbone.layers[selected_layer].mixer.ablate_attn_mat = True\n",
    "model._model.backbone.layers[selected_layer].mixer.compute_attn_matrix = True\n",
    "model._model = model._model.cuda()\n",
    "out = model._model(input_tensor)\n",
    "ablate_dict = model._model.backbone.layers[selected_layer].mixer.ablate_dict\n",
    "ablate_dict = {k:v for k,v in ablate_dict.items() if k in ['S6Attention','finalMat','withoutConv','withoutGate','withoutAct']}\n",
    "fig, axs = plt.subplots(1, len(ablate_dict), figsize=(10,len(ablate_dict.items())))\n",
    "for i,c in enumerate(ablate_dict.items()):\n",
    "    axs[i].set_title(c[0])\n",
    "    curr_attn_vec = normalize_attn_mat(c[1][0,0,:,:].abs())\n",
    "    axs[i].imshow(curr_attn_vec.cpu().detach().numpy())\n",
    "    axs[i].axis('off')\n",
    "model._model.backbone.layers[selected_layer].mixer.ablate_attn_mat = False\n",
    "model._model.backbone.layers[selected_layer].mixer.compute_attn_matrix = False"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1000x500 with 5 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "model._model.backbone.layers[selected_layer].mixer.ablate_attn_mat = False\n",
    "model._model.backbone.layers[selected_layer].mixer.ablate_attn_vec = True\n",
    "model._model = model._model.cuda()\n",
    "out = model._model(input_tensor)\n",
    "ablate_dict = model._model.backbone.layers[selected_layer].mixer.ablate_dict\n",
    "ablate_dict = {k:v for k,v in ablate_dict.items() if k in ['S6Attention','finalMat','withoutConv','withoutGate','withoutAct']}\n",
    "fig, axs = plt.subplots(1, len(ablate_dict), figsize=(10,len(ablate_dict.items())))\n",
    "for i,c in enumerate(ablate_dict.items()):\n",
    "    axs[i].set_title(c[0])\n",
    "    curr_attn_vec = normalize_attn_mat(c[1][0,0:1,:].abs())\n",
    "    axs[i].imshow(curr_attn_vec.cpu().detach().numpy())\n",
    "    axs[i].axis('off')\n",
    "model._model.backbone.layers[selected_layer].mixer.ablate_attn_mat = False\n",
    "model._model.backbone.layers[selected_layer].mixer.ablate_attn_vec = False"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "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.10.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
