{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import torch\n",
    "import transformers\n",
    "from transformers import AutoTokenizer, RwkvConfig, RwkvModel\n",
    "from attn_vis_utils import normalize_attn_mat\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "collapsed": false,
    "jupyter": {
     "outputs_hidden": false
    },
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "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 = RwkvModel.from_pretrained(\"sgugger/rwkv-430M-pile\")\n",
    "tokenizer = AutoTokenizer.from_pretrained(\"sgugger/rwkv-430M-pile\")\n",
    "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\"\n",
    "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\"\n",
    "inputs = tokenizer(prompt, return_tensors=\"pt\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {
    "collapsed": false,
    "jupyter": {
     "outputs_hidden": false
    },
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [],
   "source": [
    "selected_layer = 21\n",
    "selected_chan = [0,1,2,3,1000,1001,1002,1003]\n",
    "model.blocks[selected_layer].attention.compute_attn_matrix = True\n",
    "model.blocks[selected_layer].attention.ablate_gate = False"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {
    "collapsed": false,
    "jupyter": {
     "outputs_hidden": false
    },
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [],
   "source": [
    "outputs = model(inputs[\"input_ids\"])\n",
    "attn_mat = model.blocks[selected_layer].attention.attn_matrix"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {
    "collapsed": false,
    "jupyter": {
     "outputs_hidden": false
    },
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1000x1000 with 8 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "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.blocks[selected_layer].attention.compute_attn_matrix = False"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Visualization of Ablation variant (without gate brnach)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1000x1000 with 8 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "model.blocks[selected_layer].attention.ablate_gate = True\n",
    "model.blocks[selected_layer].attention.compute_attn_matrix = True\n",
    "outputs = model(inputs[\"input_ids\"])\n",
    "attn_mat = model.blocks[selected_layer].attention.attn_matrix\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.blocks[selected_layer].attention.compute_attn_matrix = False\n",
    "model.blocks[selected_layer].attention.ablate_gate = False"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "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'RWKV_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": [
    "## Compute Attention vector (CLS to others)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAxsAAAAZCAYAAABZ/jNfAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAAPYQAAD2EBqD+naQAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjEsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+j8jraAAADB0lEQVR4nO3du4sdVRwH8DNzd93sXfMo8iAxGIIatfARLCwkKSSg2CjY2FiJoJ1YWRrFykIstBH/AvuoaOUDUcQXQaKrSxKJuCuJIbuySXbvjLX+fotjzMEgn0/55bzuzJwz97fLsk3f930BAAC4ytr/egEAAMD/k2IDAACoQrEBAABUodgAAACqUGwAAABVKDYAAIAqFBsAAEAVig0AAKAKxQYAAFDF1NCGX5y6MWTPHTgUsue/+yRkLx55NGTrCyfziZomZtk/OU/atTMzMdu2Nc69uJTP/de+43Gavz3/ccge2HN3yEY37w/ZZOF0HLDvkmzYZ97IaPPmOPeFC4P6NtPXxeWsXR42cTsa1Gx00740n8wvDJsn8V731hX3vVruePaVkO1+7fOQ9etrIWtnZ0PWXbyUztPObopjXsrbxrnXkwGT+9ZNYpY8g++e+TKd556jT4ds+xufhWztyMGQTb8fx2w3xf099LzY6Dqmn3GgNtlj3fJy0nDgtU1ke7GUf7AfE9fCPjn08MshG/+0ErL2bDyzunO/xWz1YjpP9sw0U/G118zFs3598dc43p23xknmT8XxRvGev3n8WLrGJ+5/PIZLZ0N07MQHIXvotsMhm6z8HrKpndtDtnxvPIPHP6+mayzffB+i7AwqyfPaJe+d/nLy/DbxZ5/pnk+ubbNnV2y3gS55B2f76VrYJ6WU8uDOp0LWJ/e4uX4uZEuPHIjtNjh6dnz4S8hOPrY7ZN107HviyddDdt8zcd1bvj2frCcuaHXftnSNs5/+ELLJ+Thme9ftsXMXv2dl58vKwb0hmzmXvD+Sr2illDL6ej7Os3VLyH58dUfI9r8Qvxc0ZxbjGg/fErLx6fhMTObizWo/+ipkpZQytfeG2H9XvA/talzjO8dfSsf8U7+/bQEAAHAFFBsAAEAVig0AAKAKxQYAAFBF0/fZXyIDAAD8O36zAQAAVKHYAAAAqlBsAAAAVSg2AACAKhQbAABAFYoNAACgCsUGAABQhWIDAACoQrEBAABU8QdDDLQrvEtyvAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 1000x1000 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "selected_layer = 14\n",
    "model = RwkvModel.from_pretrained(\"sgugger/rwkv-430M-pile\")\n",
    "model.blocks[selected_layer].attention.compute_attn_vec = True\n",
    "model.blocks[selected_layer].attention.ablate_gate = False\n",
    "selected_chan = [30,31,32,33]\n",
    "outputs = model(inputs[\"input_ids\"])\n",
    "attn_vec = model.blocks[selected_layer].attention.attn_vec\n",
    "fig, axs = plt.subplots(1, len(selected_chan), figsize=(10,10))\n",
    "attn_vec = normalize_attn_mat(attn_vec[0,:,:].abs())\n",
    "for i,c in enumerate(selected_chan):\n",
    "    curr_attn_vec = attn_vec[c:c+1,:]\n",
    "    axs[i].imshow(curr_attn_vec.cpu().detach().numpy())\n",
    "    axs[i].axis('off')\n",
    "model.blocks[selected_layer].attention.compute_attn_vector = False"
   ]
  }
 ],
 "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.8.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
