{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Helper"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import sys\n",
    "\n",
    "# to import functions from `patching_utils.py` and `plotly_utils.py`,\n",
    "# we need to add the repository directory to the system path.\n",
    "project_base_dir = os.path.dirname(os.path.dirname(os.getcwd()))\n",
    "print(project_base_dir)\n",
    "if project_base_dir not in sys.path:\n",
    "    sys.path.append(project_base_dir)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch as t\n",
    "from torch import Tensor\n",
    "import torch.nn.functional as F\n",
    "\n",
    "from transformer_lens import HookedTransformer, patching, ActivationCache, utils\n",
    "from transformer_lens.hook_points import HookPoint\n",
    "\n",
    "t.set_grad_enabled(False)\n",
    "\n",
    "from jaxtyping import Float, Int, Bool\n",
    "from typing import Literal, Callable, Dict, Tuple\n",
    "from functools import partial\n",
    "\n",
    "from IPython.display import display, HTML\n",
    "from plotly_utils import imshow, line, scatter, bar\n",
    "from patching_utils import prepare_data_for_fwd\n",
    "\n",
    "from tqdm import trange"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "WARNING:root:You tried to specify center_unembed=True for a model using logit softcap, but this can't be done! Softcapping is not invariant upon adding a constantSetting center_unembed=False instead.\n",
      "Loading checkpoint shards: 100%|██████████| 8/8 [00:01<00:00,  7.87it/s]\n",
      "WARNING:root:You are not using LayerNorm, so the writing weights can't be centered! Skipping\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loaded pretrained model google/gemma-2-9b into HookedTransformer\n"
     ]
    }
   ],
   "source": [
    "device = \"cuda:0\"\n",
    "model_name = \"google/gemma-2-9b\"\n",
    "\n",
    "model = HookedTransformer.from_pretrained(model_name, device=device)\n",
    "model.set_ungroup_grouped_query_attention(True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "from data_utils import process_dataset, read_jsonl\n",
    "\n",
    "def load_data(offset):\n",
    "    setting, nmax, offset, n_icl_examples = \"setting1\", 9, offset, 4\n",
    "    filename = f\"../../data/addition/{setting}/addition_nmax{nmax}_offset{offset}.jsonl\"\n",
    "    data = read_jsonl(filename)\n",
    "    processed_data = process_dataset(data, n_icl_examples=n_icl_examples, offset=offset)\n",
    "    return processed_data"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Compute FVs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "# 0-9 token ids\n",
    "digit_token_ids = [235276, 235274, 235284, 235304, 235310, 235308, 235318, 235324, 235321, 235315]\n",
    "# FI heads\n",
    "# heads = [(39, 12), (39, 7), (36, 7), (32, 6), (32, 1), (25, 13), (32, 4), (28, 6), (24, 9), (36, 6)]\n",
    "# PT heads\n",
    "heads = [(38, 9), (38, 6), (38, 7), (35, 9), (35, 14), (31, 5), (31, 4), (29, 5)]\n",
    "# Consolidation Heads\n",
    "# heads = [(41, 4), (41, 5), (40, 11), (40, 12)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'normal_input': '4+3=7\\n3+2=5\\n6+0=6\\n3+3=6\\n1+0=', 'normal_output': '1', 'contrast_input': '4+3=8\\n3+2=6\\n6+0=7\\n3+3=7\\n1+0=', 'contrast_output': '2'}\n"
     ]
    }
   ],
   "source": [
    "data = load_data(1)\n",
    "print(data[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/25 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 25/25 [01:43<00:00,  4.15s/it]\n"
     ]
    }
   ],
   "source": [
    "fv_offset = {}\n",
    "for offset in [1]:\n",
    "    fvs = {}\n",
    "\n",
    "    data = load_data(offset)\n",
    "    batch_size = 4\n",
    "    for st in trange(0, len(data), batch_size):\n",
    "        ed = st + batch_size\n",
    "        batch = data[st: ed]\n",
    "\n",
    "        for head_layer, head_idx in heads:\n",
    "            t.cuda.empty_cache()\n",
    "            _, _, _, _, normal_cache, contrast_cache, normal_logits, contrast_logits = prepare_data_for_fwd(model, batch)\n",
    "            \n",
    "            # head_out = contrast_cache[utils.get_act_name(\"z\", head_layer)][:, -1, head_idx, :]\n",
    "            # -6 is the previous c\n",
    "            head_out = contrast_cache[utils.get_act_name(\"z\", head_layer)][:, [-24,-18,-12,-6], head_idx, :].mean(dim=1)\n",
    "\n",
    "            if (head_layer, head_idx) in fvs:\n",
    "                fvs[(head_layer, head_idx)].append(head_out)\n",
    "            else:\n",
    "                fvs[(head_layer, head_idx)] = [head_out]\n",
    "            del contrast_cache\n",
    "            del normal_cache\n",
    "    \n",
    "    for head_layer, head_idx in heads:\n",
    "        tensors = fvs[(head_layer, head_idx)]\n",
    "        fvs[(head_layer, head_idx)] = t.cat(tensors, dim=0).mean(dim=0)\n",
    "\n",
    "    fv_offset[offset] = fvs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([256])\n"
     ]
    }
   ],
   "source": [
    "print(fv_offset[1][(38, 9)].shape)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Getting Naive Prompt Logits"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['9=9\\n0=', '0=0\\n1=', '1=1\\n2=', '2=2\\n3=', '3=3\\n4=', '4=4\\n5=', '5=5\\n6=', '6=6\\n7=', '7=7\\n8=', '8=8\\n9=']\n"
     ]
    }
   ],
   "source": [
    "# 2-shot\n",
    "# prompts = [\"{}={}\\n{}={}\\n{}=\".format((i-2) % 10, (i-2) % 10, (i-1) % 10, (i-1) % 10, i, i) for i in range(10)]\n",
    "# 1-shot\n",
    "prompts = [\"{}={}\\n{}=\".format((i-1) % 10, (i-1) % 10, i, i) for i in range(10)]\n",
    "print(prompts)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "metadata": {},
   "outputs": [],
   "source": [
    "digit_logits = model.forward(prompts) # batch_size * seqlen * vocab_size\n",
    "digit_logits = digit_logits[:, -1, digit_token_ids] # batch_size, 0-9"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.plotly.v1+json": {
       "config": {
        "plotlyServerURL": "https://plot.ly",
        "staticPlot": false
       },
       "data": [
        {
         "coloraxis": "coloraxis",
         "hovertemplate": "Output: %{x}<br>Input: %{y}<br>color: %{z}<extra></extra>",
         "name": "0",
         "type": "heatmap",
         "xaxis": "x",
         "yaxis": "y",
         "z": [
          [
           29.89043,
           28.08857,
           26.65562,
           26.233734,
           25.934788,
           26.132286,
           25.969627,
           25.483318,
           26.247473,
           27.90907
          ],
          [
           28.11562,
           29.829212,
           26.902702,
           26.004807,
           25.600418,
           25.70069,
           24.933422,
           24.647673,
           24.566225,
           24.734179
          ],
          [
           26.71092,
           28.661032,
           29.83952,
           27.14962,
           27.237804,
           26.06544,
           25.239666,
           24.911058,
           25.029655,
           24.67161
          ],
          [
           26.042082,
           27.335205,
           27.681135,
           29.863388,
           27.13399,
           26.536213,
           26.345682,
           25.136894,
           24.958124,
           24.841707
          ],
          [
           26.071056,
           27.12916,
           27.45146,
           27.578526,
           29.847301,
           27.116219,
           26.276031,
           25.851603,
           25.602121,
           25.238762
          ],
          [
           26.25582,
           27.430923,
           26.805584,
           27.004581,
           27.583548,
           29.868237,
           26.930416,
           26.025026,
           26.06893,
           25.92885
          ],
          [
           26.435617,
           27.645666,
           26.792297,
           26.914024,
           27.005123,
           28.02827,
           29.846666,
           26.923157,
           26.36834,
           26.129574
          ],
          [
           26.123068,
           27.490652,
           26.48573,
           26.459522,
           26.422197,
           26.935287,
           27.903133,
           29.80917,
           27.076332,
           26.41062
          ],
          [
           26.056778,
           27.347534,
           26.354536,
           26.008753,
           26.007908,
           26.155184,
           26.729809,
           27.610296,
           29.74916,
           26.949507
          ],
          [
           26.1761,
           27.61992,
           26.271347,
           26.094444,
           25.819448,
           26.03549,
           26.36822,
           26.680185,
           27.723099,
           29.751955
          ]
         ]
        }
       ],
       "layout": {
        "coloraxis": {
         "cmax": 30,
         "cmid": 0,
         "cmin": 24,
         "colorscale": [
          [
           0,
           "rgb(247,251,255)"
          ],
          [
           0.125,
           "rgb(222,235,247)"
          ],
          [
           0.25,
           "rgb(198,219,239)"
          ],
          [
           0.375,
           "rgb(158,202,225)"
          ],
          [
           0.5,
           "rgb(107,174,214)"
          ],
          [
           0.625,
           "rgb(66,146,198)"
          ],
          [
           0.75,
           "rgb(33,113,181)"
          ],
          [
           0.875,
           "rgb(8,81,156)"
          ],
          [
           1,
           "rgb(8,48,107)"
          ]
         ]
        },
        "height": 400,
        "template": {
         "data": {
          "bar": [
           {
            "error_x": {
             "color": "#2a3f5f"
            },
            "error_y": {
             "color": "#2a3f5f"
            },
            "marker": {
             "line": {
              "color": "#E5ECF6",
              "width": 0.5
             },
             "pattern": {
              "fillmode": "overlay",
              "size": 10,
              "solidity": 0.2
             }
            },
            "type": "bar"
           }
          ],
          "barpolar": [
           {
            "marker": {
             "line": {
              "color": "#E5ECF6",
              "width": 0.5
             },
             "pattern": {
              "fillmode": "overlay",
              "size": 10,
              "solidity": 0.2
             }
            },
            "type": "barpolar"
           }
          ],
          "carpet": [
           {
            "aaxis": {
             "endlinecolor": "#2a3f5f",
             "gridcolor": "white",
             "linecolor": "white",
             "minorgridcolor": "white",
             "startlinecolor": "#2a3f5f"
            },
            "baxis": {
             "endlinecolor": "#2a3f5f",
             "gridcolor": "white",
             "linecolor": "white",
             "minorgridcolor": "white",
             "startlinecolor": "#2a3f5f"
            },
            "type": "carpet"
           }
          ],
          "choropleth": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "type": "choropleth"
           }
          ],
          "contour": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "colorscale": [
             [
              0,
              "#0d0887"
             ],
             [
              0.1111111111111111,
              "#46039f"
             ],
             [
              0.2222222222222222,
              "#7201a8"
             ],
             [
              0.3333333333333333,
              "#9c179e"
             ],
             [
              0.4444444444444444,
              "#bd3786"
             ],
             [
              0.5555555555555556,
              "#d8576b"
             ],
             [
              0.6666666666666666,
              "#ed7953"
             ],
             [
              0.7777777777777778,
              "#fb9f3a"
             ],
             [
              0.8888888888888888,
              "#fdca26"
             ],
             [
              1,
              "#f0f921"
             ]
            ],
            "type": "contour"
           }
          ],
          "contourcarpet": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "type": "contourcarpet"
           }
          ],
          "heatmap": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "colorscale": [
             [
              0,
              "#0d0887"
             ],
             [
              0.1111111111111111,
              "#46039f"
             ],
             [
              0.2222222222222222,
              "#7201a8"
             ],
             [
              0.3333333333333333,
              "#9c179e"
             ],
             [
              0.4444444444444444,
              "#bd3786"
             ],
             [
              0.5555555555555556,
              "#d8576b"
             ],
             [
              0.6666666666666666,
              "#ed7953"
             ],
             [
              0.7777777777777778,
              "#fb9f3a"
             ],
             [
              0.8888888888888888,
              "#fdca26"
             ],
             [
              1,
              "#f0f921"
             ]
            ],
            "type": "heatmap"
           }
          ],
          "heatmapgl": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "colorscale": [
             [
              0,
              "#0d0887"
             ],
             [
              0.1111111111111111,
              "#46039f"
             ],
             [
              0.2222222222222222,
              "#7201a8"
             ],
             [
              0.3333333333333333,
              "#9c179e"
             ],
             [
              0.4444444444444444,
              "#bd3786"
             ],
             [
              0.5555555555555556,
              "#d8576b"
             ],
             [
              0.6666666666666666,
              "#ed7953"
             ],
             [
              0.7777777777777778,
              "#fb9f3a"
             ],
             [
              0.8888888888888888,
              "#fdca26"
             ],
             [
              1,
              "#f0f921"
             ]
            ],
            "type": "heatmapgl"
           }
          ],
          "histogram": [
           {
            "marker": {
             "pattern": {
              "fillmode": "overlay",
              "size": 10,
              "solidity": 0.2
             }
            },
            "type": "histogram"
           }
          ],
          "histogram2d": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "colorscale": [
             [
              0,
              "#0d0887"
             ],
             [
              0.1111111111111111,
              "#46039f"
             ],
             [
              0.2222222222222222,
              "#7201a8"
             ],
             [
              0.3333333333333333,
              "#9c179e"
             ],
             [
              0.4444444444444444,
              "#bd3786"
             ],
             [
              0.5555555555555556,
              "#d8576b"
             ],
             [
              0.6666666666666666,
              "#ed7953"
             ],
             [
              0.7777777777777778,
              "#fb9f3a"
             ],
             [
              0.8888888888888888,
              "#fdca26"
             ],
             [
              1,
              "#f0f921"
             ]
            ],
            "type": "histogram2d"
           }
          ],
          "histogram2dcontour": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "colorscale": [
             [
              0,
              "#0d0887"
             ],
             [
              0.1111111111111111,
              "#46039f"
             ],
             [
              0.2222222222222222,
              "#7201a8"
             ],
             [
              0.3333333333333333,
              "#9c179e"
             ],
             [
              0.4444444444444444,
              "#bd3786"
             ],
             [
              0.5555555555555556,
              "#d8576b"
             ],
             [
              0.6666666666666666,
              "#ed7953"
             ],
             [
              0.7777777777777778,
              "#fb9f3a"
             ],
             [
              0.8888888888888888,
              "#fdca26"
             ],
             [
              1,
              "#f0f921"
             ]
            ],
            "type": "histogram2dcontour"
           }
          ],
          "mesh3d": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "type": "mesh3d"
           }
          ],
          "parcoords": [
           {
            "line": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "parcoords"
           }
          ],
          "pie": [
           {
            "automargin": true,
            "type": "pie"
           }
          ],
          "scatter": [
           {
            "fillpattern": {
             "fillmode": "overlay",
             "size": 10,
             "solidity": 0.2
            },
            "type": "scatter"
           }
          ],
          "scatter3d": [
           {
            "line": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scatter3d"
           }
          ],
          "scattercarpet": [
           {
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scattercarpet"
           }
          ],
          "scattergeo": [
           {
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scattergeo"
           }
          ],
          "scattergl": [
           {
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scattergl"
           }
          ],
          "scattermapbox": [
           {
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scattermapbox"
           }
          ],
          "scatterpolar": [
           {
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scatterpolar"
           }
          ],
          "scatterpolargl": [
           {
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scatterpolargl"
           }
          ],
          "scatterternary": [
           {
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scatterternary"
           }
          ],
          "surface": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "colorscale": [
             [
              0,
              "#0d0887"
             ],
             [
              0.1111111111111111,
              "#46039f"
             ],
             [
              0.2222222222222222,
              "#7201a8"
             ],
             [
              0.3333333333333333,
              "#9c179e"
             ],
             [
              0.4444444444444444,
              "#bd3786"
             ],
             [
              0.5555555555555556,
              "#d8576b"
             ],
             [
              0.6666666666666666,
              "#ed7953"
             ],
             [
              0.7777777777777778,
              "#fb9f3a"
             ],
             [
              0.8888888888888888,
              "#fdca26"
             ],
             [
              1,
              "#f0f921"
             ]
            ],
            "type": "surface"
           }
          ],
          "table": [
           {
            "cells": {
             "fill": {
              "color": "#EBF0F8"
             },
             "line": {
              "color": "white"
             }
            },
            "header": {
             "fill": {
              "color": "#C8D4E3"
             },
             "line": {
              "color": "white"
             }
            },
            "type": "table"
           }
          ]
         },
         "layout": {
          "annotationdefaults": {
           "arrowcolor": "#2a3f5f",
           "arrowhead": 0,
           "arrowwidth": 1
          },
          "autotypenumbers": "strict",
          "coloraxis": {
           "colorbar": {
            "outlinewidth": 0,
            "ticks": ""
           }
          },
          "colorscale": {
           "diverging": [
            [
             0,
             "#8e0152"
            ],
            [
             0.1,
             "#c51b7d"
            ],
            [
             0.2,
             "#de77ae"
            ],
            [
             0.3,
             "#f1b6da"
            ],
            [
             0.4,
             "#fde0ef"
            ],
            [
             0.5,
             "#f7f7f7"
            ],
            [
             0.6,
             "#e6f5d0"
            ],
            [
             0.7,
             "#b8e186"
            ],
            [
             0.8,
             "#7fbc41"
            ],
            [
             0.9,
             "#4d9221"
            ],
            [
             1,
             "#276419"
            ]
           ],
           "sequential": [
            [
             0,
             "#0d0887"
            ],
            [
             0.1111111111111111,
             "#46039f"
            ],
            [
             0.2222222222222222,
             "#7201a8"
            ],
            [
             0.3333333333333333,
             "#9c179e"
            ],
            [
             0.4444444444444444,
             "#bd3786"
            ],
            [
             0.5555555555555556,
             "#d8576b"
            ],
            [
             0.6666666666666666,
             "#ed7953"
            ],
            [
             0.7777777777777778,
             "#fb9f3a"
            ],
            [
             0.8888888888888888,
             "#fdca26"
            ],
            [
             1,
             "#f0f921"
            ]
           ],
           "sequentialminus": [
            [
             0,
             "#0d0887"
            ],
            [
             0.1111111111111111,
             "#46039f"
            ],
            [
             0.2222222222222222,
             "#7201a8"
            ],
            [
             0.3333333333333333,
             "#9c179e"
            ],
            [
             0.4444444444444444,
             "#bd3786"
            ],
            [
             0.5555555555555556,
             "#d8576b"
            ],
            [
             0.6666666666666666,
             "#ed7953"
            ],
            [
             0.7777777777777778,
             "#fb9f3a"
            ],
            [
             0.8888888888888888,
             "#fdca26"
            ],
            [
             1,
             "#f0f921"
            ]
           ]
          },
          "colorway": [
           "#636efa",
           "#EF553B",
           "#00cc96",
           "#ab63fa",
           "#FFA15A",
           "#19d3f3",
           "#FF6692",
           "#B6E880",
           "#FF97FF",
           "#FECB52"
          ],
          "font": {
           "color": "#2a3f5f"
          },
          "geo": {
           "bgcolor": "white",
           "lakecolor": "white",
           "landcolor": "#E5ECF6",
           "showlakes": true,
           "showland": true,
           "subunitcolor": "white"
          },
          "hoverlabel": {
           "align": "left"
          },
          "hovermode": "closest",
          "mapbox": {
           "style": "light"
          },
          "paper_bgcolor": "white",
          "plot_bgcolor": "#E5ECF6",
          "polar": {
           "angularaxis": {
            "gridcolor": "white",
            "linecolor": "white",
            "ticks": ""
           },
           "bgcolor": "#E5ECF6",
           "radialaxis": {
            "gridcolor": "white",
            "linecolor": "white",
            "ticks": ""
           }
          },
          "scene": {
           "xaxis": {
            "backgroundcolor": "#E5ECF6",
            "gridcolor": "white",
            "gridwidth": 2,
            "linecolor": "white",
            "showbackground": true,
            "ticks": "",
            "zerolinecolor": "white"
           },
           "yaxis": {
            "backgroundcolor": "#E5ECF6",
            "gridcolor": "white",
            "gridwidth": 2,
            "linecolor": "white",
            "showbackground": true,
            "ticks": "",
            "zerolinecolor": "white"
           },
           "zaxis": {
            "backgroundcolor": "#E5ECF6",
            "gridcolor": "white",
            "gridwidth": 2,
            "linecolor": "white",
            "showbackground": true,
            "ticks": "",
            "zerolinecolor": "white"
           }
          },
          "shapedefaults": {
           "line": {
            "color": "#2a3f5f"
           }
          },
          "ternary": {
           "aaxis": {
            "gridcolor": "white",
            "linecolor": "white",
            "ticks": ""
           },
           "baxis": {
            "gridcolor": "white",
            "linecolor": "white",
            "ticks": ""
           },
           "bgcolor": "#E5ECF6",
           "caxis": {
            "gridcolor": "white",
            "linecolor": "white",
            "ticks": ""
           }
          },
          "title": {
           "x": 0.05
          },
          "xaxis": {
           "automargin": true,
           "gridcolor": "white",
           "linecolor": "white",
           "ticks": "",
           "title": {
            "standoff": 15
           },
           "zerolinecolor": "white",
           "zerolinewidth": 2
          },
          "yaxis": {
           "automargin": true,
           "gridcolor": "white",
           "linecolor": "white",
           "ticks": "",
           "title": {
            "standoff": 15
           },
           "zerolinecolor": "white",
           "zerolinewidth": 2
          }
         }
        },
        "title": {
         "text": "Clean Baseline"
        },
        "width": 400,
        "xaxis": {
         "anchor": "y",
         "constrain": "domain",
         "domain": [
          0,
          1
         ],
         "scaleanchor": "y",
         "title": {
          "text": "Output"
         }
        },
        "yaxis": {
         "anchor": "x",
         "autorange": "reversed",
         "constrain": "domain",
         "domain": [
          0,
          1
         ],
         "title": {
          "text": "Input"
         }
        }
       }
      },
      "text/html": [
       "<div>                            <div id=\"a2597ae9-79c4-47be-bdd1-efe8fbfc53e3\" class=\"plotly-graph-div\" style=\"height:400px; width:400px;\"></div>            <script type=\"text/javascript\">                require([\"plotly\"], function(Plotly) {                    window.PLOTLYENV=window.PLOTLYENV || {};                                    if (document.getElementById(\"a2597ae9-79c4-47be-bdd1-efe8fbfc53e3\")) {                    Plotly.newPlot(                        \"a2597ae9-79c4-47be-bdd1-efe8fbfc53e3\",                        [{\"coloraxis\":\"coloraxis\",\"name\":\"0\",\"z\":[[29.89043,28.08857,26.65562,26.233734,25.934788,26.132286,25.969627,25.483318,26.247473,27.90907],[28.11562,29.829212,26.902702,26.004807,25.600418,25.70069,24.933422,24.647673,24.566225,24.734179],[26.71092,28.661032,29.83952,27.14962,27.237804,26.06544,25.239666,24.911058,25.029655,24.67161],[26.042082,27.335205,27.681135,29.863388,27.13399,26.536213,26.345682,25.136894,24.958124,24.841707],[26.071056,27.12916,27.45146,27.578526,29.847301,27.116219,26.276031,25.851603,25.602121,25.238762],[26.25582,27.430923,26.805584,27.004581,27.583548,29.868237,26.930416,26.025026,26.06893,25.92885],[26.435617,27.645666,26.792297,26.914024,27.005123,28.02827,29.846666,26.923157,26.36834,26.129574],[26.123068,27.490652,26.48573,26.459522,26.422197,26.935287,27.903133,29.80917,27.076332,26.41062],[26.056778,27.347534,26.354536,26.008753,26.007908,26.155184,26.729809,27.610296,29.74916,26.949507],[26.1761,27.61992,26.271347,26.094444,25.819448,26.03549,26.36822,26.680185,27.723099,29.751955]],\"type\":\"heatmap\",\"xaxis\":\"x\",\"yaxis\":\"y\",\"hovertemplate\":\"Output: %{x}\\u003cbr\\u003eInput: %{y}\\u003cbr\\u003ecolor: %{z}\\u003cextra\\u003e\\u003c\\u002fextra\\u003e\"}],                        {\"template\":{\"data\":{\"histogram2dcontour\":[{\"type\":\"histogram2dcontour\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"choropleth\":[{\"type\":\"choropleth\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}],\"histogram2d\":[{\"type\":\"histogram2d\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"heatmap\":[{\"type\":\"heatmap\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"heatmapgl\":[{\"type\":\"heatmapgl\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"contourcarpet\":[{\"type\":\"contourcarpet\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}],\"contour\":[{\"type\":\"contour\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"surface\":[{\"type\":\"surface\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"mesh3d\":[{\"type\":\"mesh3d\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}],\"scatter\":[{\"fillpattern\":{\"fillmode\":\"overlay\",\"size\":10,\"solidity\":0.2},\"type\":\"scatter\"}],\"parcoords\":[{\"type\":\"parcoords\",\"line\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scatterpolargl\":[{\"type\":\"scatterpolargl\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"bar\":[{\"error_x\":{\"color\":\"#2a3f5f\"},\"error_y\":{\"color\":\"#2a3f5f\"},\"marker\":{\"line\":{\"color\":\"#E5ECF6\",\"width\":0.5},\"pattern\":{\"fillmode\":\"overlay\",\"size\":10,\"solidity\":0.2}},\"type\":\"bar\"}],\"scattergeo\":[{\"type\":\"scattergeo\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scatterpolar\":[{\"type\":\"scatterpolar\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"histogram\":[{\"marker\":{\"pattern\":{\"fillmode\":\"overlay\",\"size\":10,\"solidity\":0.2}},\"type\":\"histogram\"}],\"scattergl\":[{\"type\":\"scattergl\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scatter3d\":[{\"type\":\"scatter3d\",\"line\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}},\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scattermapbox\":[{\"type\":\"scattermapbox\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scatterternary\":[{\"type\":\"scatterternary\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scattercarpet\":[{\"type\":\"scattercarpet\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"carpet\":[{\"aaxis\":{\"endlinecolor\":\"#2a3f5f\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"minorgridcolor\":\"white\",\"startlinecolor\":\"#2a3f5f\"},\"baxis\":{\"endlinecolor\":\"#2a3f5f\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"minorgridcolor\":\"white\",\"startlinecolor\":\"#2a3f5f\"},\"type\":\"carpet\"}],\"table\":[{\"cells\":{\"fill\":{\"color\":\"#EBF0F8\"},\"line\":{\"color\":\"white\"}},\"header\":{\"fill\":{\"color\":\"#C8D4E3\"},\"line\":{\"color\":\"white\"}},\"type\":\"table\"}],\"barpolar\":[{\"marker\":{\"line\":{\"color\":\"#E5ECF6\",\"width\":0.5},\"pattern\":{\"fillmode\":\"overlay\",\"size\":10,\"solidity\":0.2}},\"type\":\"barpolar\"}],\"pie\":[{\"automargin\":true,\"type\":\"pie\"}]},\"layout\":{\"autotypenumbers\":\"strict\",\"colorway\":[\"#636efa\",\"#EF553B\",\"#00cc96\",\"#ab63fa\",\"#FFA15A\",\"#19d3f3\",\"#FF6692\",\"#B6E880\",\"#FF97FF\",\"#FECB52\"],\"font\":{\"color\":\"#2a3f5f\"},\"hovermode\":\"closest\",\"hoverlabel\":{\"align\":\"left\"},\"paper_bgcolor\":\"white\",\"plot_bgcolor\":\"#E5ECF6\",\"polar\":{\"bgcolor\":\"#E5ECF6\",\"angularaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"},\"radialaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"}},\"ternary\":{\"bgcolor\":\"#E5ECF6\",\"aaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"},\"baxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"},\"caxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"}},\"coloraxis\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}},\"colorscale\":{\"sequential\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]],\"sequentialminus\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]],\"diverging\":[[0,\"#8e0152\"],[0.1,\"#c51b7d\"],[0.2,\"#de77ae\"],[0.3,\"#f1b6da\"],[0.4,\"#fde0ef\"],[0.5,\"#f7f7f7\"],[0.6,\"#e6f5d0\"],[0.7,\"#b8e186\"],[0.8,\"#7fbc41\"],[0.9,\"#4d9221\"],[1,\"#276419\"]]},\"xaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\",\"title\":{\"standoff\":15},\"zerolinecolor\":\"white\",\"automargin\":true,\"zerolinewidth\":2},\"yaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\",\"title\":{\"standoff\":15},\"zerolinecolor\":\"white\",\"automargin\":true,\"zerolinewidth\":2},\"scene\":{\"xaxis\":{\"backgroundcolor\":\"#E5ECF6\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"showbackground\":true,\"ticks\":\"\",\"zerolinecolor\":\"white\",\"gridwidth\":2},\"yaxis\":{\"backgroundcolor\":\"#E5ECF6\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"showbackground\":true,\"ticks\":\"\",\"zerolinecolor\":\"white\",\"gridwidth\":2},\"zaxis\":{\"backgroundcolor\":\"#E5ECF6\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"showbackground\":true,\"ticks\":\"\",\"zerolinecolor\":\"white\",\"gridwidth\":2}},\"shapedefaults\":{\"line\":{\"color\":\"#2a3f5f\"}},\"annotationdefaults\":{\"arrowcolor\":\"#2a3f5f\",\"arrowhead\":0,\"arrowwidth\":1},\"geo\":{\"bgcolor\":\"white\",\"landcolor\":\"#E5ECF6\",\"subunitcolor\":\"white\",\"showland\":true,\"showlakes\":true,\"lakecolor\":\"white\"},\"title\":{\"x\":0.05},\"mapbox\":{\"style\":\"light\"}}},\"xaxis\":{\"anchor\":\"y\",\"domain\":[0.0,1.0],\"scaleanchor\":\"y\",\"constrain\":\"domain\",\"title\":{\"text\":\"Output\"}},\"yaxis\":{\"anchor\":\"x\",\"domain\":[0.0,1.0],\"autorange\":\"reversed\",\"constrain\":\"domain\",\"title\":{\"text\":\"Input\"}},\"coloraxis\":{\"colorscale\":[[0.0,\"rgb(247,251,255)\"],[0.125,\"rgb(222,235,247)\"],[0.25,\"rgb(198,219,239)\"],[0.375,\"rgb(158,202,225)\"],[0.5,\"rgb(107,174,214)\"],[0.625,\"rgb(66,146,198)\"],[0.75,\"rgb(33,113,181)\"],[0.875,\"rgb(8,81,156)\"],[1.0,\"rgb(8,48,107)\"]],\"cmid\":0.0,\"cmin\":24,\"cmax\":30},\"title\":{\"text\":\"Clean Baseline\"},\"height\":400,\"width\":400},                        {\"staticPlot\": false, \"responsive\": true}                    ).then(function(){\n",
       "                            \n",
       "var gd = document.getElementById('a2597ae9-79c4-47be-bdd1-efe8fbfc53e3');\n",
       "var x = new MutationObserver(function (mutations, observer) {{\n",
       "        var display = window.getComputedStyle(gd).display;\n",
       "        if (!display || display === 'none') {{\n",
       "            console.log([gd, 'removed!']);\n",
       "            Plotly.purge(gd);\n",
       "            observer.disconnect();\n",
       "        }}\n",
       "}});\n",
       "\n",
       "// Listen for the removal of the full notebook cells\n",
       "var notebookContainer = gd.closest('#notebook-container');\n",
       "if (notebookContainer) {{\n",
       "    x.observe(notebookContainer, {childList: true});\n",
       "}}\n",
       "\n",
       "// Listen for the clearing of the current output cell\n",
       "var outputEl = gd.closest('.output');\n",
       "if (outputEl) {{\n",
       "    x.observe(outputEl, {childList: true});\n",
       "}}\n",
       "\n",
       "                        })                };                });            </script>        </div>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "imshow(digit_logits,\n",
    "    labels={\"x\": \"Output\", \"y\": \"Input\"},\n",
    "    title=\"Clean Baseline\",\n",
    "    width=400,\n",
    "    height=400,\n",
    "    zmin=24,\n",
    "    zmax=30,\n",
    "    color_continuous_scale=\"Blues\"\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Apply FVs to Naive Prompts"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "metadata": {},
   "outputs": [],
   "source": [
    "def apply_fv_hook(\n",
    "    head_out: Float[Tensor, \"batch pos d_model\"],\n",
    "    hook: HookPoint,\n",
    "    head_idx: int,\n",
    "    fvs: Dict[Tuple[int, int], Tensor],\n",
    ") -> Float[Tensor, \"batch pos d_model\"]:\n",
    "    # head_out[:, -1, head_idx, :] += fvs[(hook.layer(), head_idx)]\n",
    "    # -4 is the answer in the previous ICL example\n",
    "    head_out[:, -4, head_idx, :] += fvs[(hook.layer(), head_idx)]\n",
    "    # head_out[:, -8, head_idx, :] += fvs[(hook.layer(), head_idx)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "metadata": {},
   "outputs": [],
   "source": [
    "head_diffs_offset = {}\n",
    "for offset in [1]:\n",
    "    head_diffs = {}\n",
    "    for head_layer, head_idx in heads:\n",
    "        fwd_hooks = [(utils.get_act_name(\"z\", head_layer), partial(apply_fv_hook, head_idx=head_idx, fvs=fv_offset[offset]))]\n",
    "        fv_applied_logits = model.run_with_hooks(prompts, fwd_hooks=fwd_hooks)\n",
    "\n",
    "        fv_applied_logits = fv_applied_logits[:, -1, digit_token_ids] # batch_size x [0-9]\n",
    "\n",
    "        diff = fv_applied_logits - digit_logits\n",
    "        head_diffs[(head_layer, head_idx)] = diff\n",
    "    head_diffs_offset[offset] = head_diffs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "metadata": {},
   "outputs": [],
   "source": [
    "# aggregated effect of 4 heads\n",
    "aggregated_diff = {}\n",
    "for offset in [1]:\n",
    "\n",
    "    fwd_hooks = [(utils.get_act_name(\"z\", head_layer), partial(apply_fv_hook, head_idx=head_idx, fvs=fv_offset[offset])) for head_layer, head_idx in heads]\n",
    "    fv_applied_logits = model.run_with_hooks(prompts, fwd_hooks=fwd_hooks)\n",
    "\n",
    "    fv_applied_logits = fv_applied_logits[:, -1, digit_token_ids] # batch_size x [0-9]\n",
    "\n",
    "    diff = fv_applied_logits - digit_logits\n",
    "    normalized_diff = diff - diff.mean(0).mean(0)\n",
    "    aggregated_diff[offset] = normalized_diff\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Plotting"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "\n",
    "plt.rcParams['font.family'] = 'sans-serif' \n",
    "plt.rcParams['font.sans-serif'] = 'DejaVu Serif' "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Individual effect and aggregated effect"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAwEAAAFpCAYAAADEJyQLAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8ekN5oAAAACXBIWXMAAA9hAAAPYQGoP6dpAABZIklEQVR4nO3deXhU5fk//veZSWaSkAUIS0oIYS0CRYFAWMISEQxlFftzRZaidaFUgRY+4kcWKWvVlo+21AUQwa36Kwi1ggoatKKACEIpRMQAMSEhbJmsk8zM8/2DZiQkYe6TzGQyc96v65rryszcec5z5n7mzDxzlltTSikQEREREZFhmPzdASIiIiIialicBBARERERGQwnAUREREREBsNJABERERGRwXASQERERERkMJwEEBEREREZDCcBREREREQGw0kAEREREZHBcBJARERERGQwnARcx759+zBgwABomoa+ffti9+7dAIDdu3ejb9++0DQNAwYMwL59+wAAW7ZsQVpaGkaOHImbbroJkyZNQkFBgbu9vLw83HHHHUhOTkZycjLuvvtuXLhwodblf//99xg7diyGDh2Knj17Yu3atR77fPr0aSxYsKDKY4sXL0Z6enqVfixYsADl5eV6Xg66Dj1jxdvjBAA2bdqElJQUDB06FN27d8fGjRt9ur5Ulb/yf+rUKcTFxSE1NdV96927N2688cYGWW/6kTfHwLRp06rkNDU1Ff/5z39qXfbBgwdxyy23YPDgwejVqxf+8Y9/+Hx9g5G3P/P15hEA3n//fcTFxWHDhg21xhw/fhyhoaHXjanE7wR0XYquKzMzUwFQBw8erPL4wYMHFQCVmZnpfiwtLU1t375dKaWU3W5Xffr0UY8++qj7+bvuukuNHTtWuVwu5XQ61ejRo9WUKVNqXG5FRYXq1q2beu6555RSSp0+fVpFRUWpjz/+uNa+Xr58WfXq1UudPn3avbw9e/aoRYsWqU8++US98soratGiRUoppdatW6ceeOABvS8HXYd0rHhznCil1ObNm9Xw4cNVSUmJUkqpXbt2qWXLlnl35cgjf+T/9OnT6pFHHqny2KpVq9SSJUu8t2Ik5q0xMHXqVPEyL126pFq0aKG2bdumlFJq//79KiwsTGVkZNRrXYzKm5/5evKolFIrVqxQjz32mGrTpo165ZVXao0bP368ioiIuG6M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",
      "text/plain": [
       "<Figure size 1000x400 with 10 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.gridspec as gridspec\n",
    "\n",
    "offset = 1\n",
    "\n",
    "heads_display_order = heads\n",
    "# heads_display_order = [(25,13)] + [(32,4), (28,6), (24,9)] \n",
    "matrices = [head_diffs_offset[offset][(layer, idx)].cpu().numpy() for layer, idx in heads_display_order] + [aggregated_diff[offset].cpu().numpy()]\n",
    "titles =  [f\"H{l}.{h}\" for l, h in heads_display_order] + [\"8 Heads\"]\n",
    "for i in [0, 4, 7]:\n",
    "    titles[i] += \" (*)\"\n",
    "\n",
    "# Create figure with GridSpec: 2 rows, 10 columns\n",
    "fig = plt.figure(figsize=(10, 4))\n",
    "gs = gridspec.GridSpec(2, 10, figure=fig, wspace=0.5, hspace=0.3)\n",
    "\n",
    "axes = []\n",
    "\n",
    "# Top row: 5 subplots filling all 10 columns\n",
    "for i in range(5):\n",
    "    ax = fig.add_subplot(gs[0, 2*i:2*(i+1)])\n",
    "    axes.append(ax)\n",
    "\n",
    "# Bottom row: 4 subplots, centered (leave 1 col margin on each side)\n",
    "for i in range(4):\n",
    "    ax = fig.add_subplot(gs[1, 1+2*i:1+2*(i+1)])\n",
    "    axes.append(ax)\n",
    "\n",
    "# Plot each matrix\n",
    "for i, (ax, matrix, title) in enumerate(zip(axes, matrices, titles)):\n",
    "    if i in [0, 4, 7]:\n",
    "        im = ax.imshow(matrix, cmap=\"RdBu\", vmin=-0.02, vmax=0.02)\n",
    "    else:\n",
    "        im = ax.imshow(matrix, cmap=\"RdBu\", vmin=-0.2, vmax=0.2)\n",
    "    ax.set_title(title, fontsize=9)\n",
    "    ax.set_xlabel(\"Output\", fontsize=9)\n",
    "    if i in [0, 5]:  # first in each row\n",
    "        ax.set_ylabel(\"Input\", fontsize=9)\n",
    "    else:\n",
    "        ax.set_yticks([0, 5])\n",
    "        ax.set_yticklabels([\"\",\"\"])\n",
    "\n",
    "# Add shared colorbar\n",
    "cbar = fig.colorbar(im, ax=axes, shrink=0.92, ticks=[-0.2, 0, 0.2])\n",
    "cbar.ax.tick_params(labelsize=9)\n",
    "\n",
    "# plt.tight_layout()\n",
    "plt.savefig(\"figures/gemma_2_pt_head_offset{}.pdf\".format(offset), dpi=300, bbox_inches='tight', pad_inches=0.0)\n",
    "plt.show()\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "fi4",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.20"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
