{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "if 'notebooks' in os.getcwd():\n",
    "    os.chdir('..')\n",
    "\n",
    "save_dir = 'notebooks/plots/analysis'\n",
    "os.makedirs(save_dir, exist_ok=True)\n",
    "\n",
    "import string\n",
    "from character_tokenizer import CharacterTokenizer\n",
    "\n",
    "tokenizer = CharacterTokenizer(string.ascii_letters + string.digits + string.punctuation + ' ')\n",
    "tokenizer.padding_side == 'left'\n",
    "\n",
    "from tasks import task_registry\n",
    "from data import add_special_tokens, tokenization_train, PromptAnswerDataCollator\n",
    "import numpy as np\n",
    "\n",
    "collator = PromptAnswerDataCollator(tokenizer=tokenizer)\n",
    "\n",
    "# ckpt_dir = 'out/-llama-384-6-6-1024-rope-copy-l=6_17-MQAR-l=6_33-SFT-seed-43'\n",
    "# ckpt_dir = 'out/-llama-384-6-6-1024-rope-capitalize_reverse-l=6_17-capitalize-l=6_33-reverse-l=6_33-SFT-seed-45'\n",
    "# ckpt_dir = 'out/-llama-384-6-6-1024-rope-reverse_add-la=1_17-lb=1_17-reverse_sub-la=1_33-lb=1_33-SFT-seed-45'\n",
    "ckpt_dir = 'out/-llama-384-6-6-1024-rope-reverse_add-la=1_17-lb=1_17-reverse_add_no_carry-la=1_33-lb=1_33-reverse_add_only_carry-la=1_33-lb=1_33-SFT-seed-45'\n",
    "# ckpt_dir = 'out/-llama-384-6-6-1024-rope-copy-l=6_17-reverse-l=6_33-SFT-seed-44'\n",
    "# ckpt_dir = 'out/-llama-384-6-6-1024-rope-reverse_add-la=1_17-lb=1_17-copy_first_op-la=1_33-lb=1_33-SFT-seed-43'\n",
    "\n",
    "# tasks = {'A': 'copy', 'B': 'MQAR'}\n",
    "# tasks = {'A': 'capitalize_reverse', 'B': 'capitalize'}\n",
    "# tasks = {'A': 'capitalize_reverse', 'C': 'reverse'}\n",
    "# tasks = {'B': 'capitalize', 'C': 'reverse'}\n",
    "# tasks = {'A': 'reverse_add', 'B': 'reverse_sub'}\n",
    "tasks = {'A': 'reverse_add', 'B': 'reverse_add_no_carry'}\n",
    "# tasks = {'A': 'copy', 'B': 'reverse'}\n",
    "# tasks = {'A': 'reverse_add', 'B': 'copy_first_op'}\n",
    "\n",
    "import torch\n",
    "torch.no_grad().__enter__()\n",
    "from transformers import AutoModelForCausalLM, LlamaForCausalLM\n",
    "# from transformer_lens import HookedTransformer\n",
    "\n",
    "ckpt_paths = [os.path.join(ckpt_dir, d) for d in os.listdir(ckpt_dir) if d.startswith('checkpoint-')]\n",
    "ckpt_nums = [int(d.split('-')[-1]) for d in ckpt_paths]\n",
    "ckpt_paths = [ckpt_paths[i] for i in np.argsort(ckpt_nums)]\n",
    "ckpt_nums = sorted(ckpt_nums)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_hs_attn(ckpt_paths, tasks):\n",
    "    data = {}\n",
    "\n",
    "    for task_id, task_name in tasks.items():\n",
    "        batch = []\n",
    "        rng = np.random.default_rng(42)\n",
    "        for i in range(1024):\n",
    "            prompt, target, loss_mask = task_registry[task_name](rng=rng, la=[16, 33])\n",
    "            if loss_mask is None:\n",
    "                loss_mask = [1] * len(target)\n",
    "            ex = {'prompt': [prompt], 'target': [target], 'loss_mask': [loss_mask]}\n",
    "            ex = add_special_tokens(ex, tokenizer, task_id=task_id)\n",
    "            ex = tokenization_train(ex, tokenizer)\n",
    "            batch += [{key: value[i] for key, value in ex.items()} for i in range(len(ex['input_ids']))]\n",
    "        batch = collator(batch)\n",
    "        data[task_id] = batch\n",
    "\n",
    "    # Print the shape of the data\n",
    "    # for task_id, batch in data.items():\n",
    "        # print(f\"Task {task_id}:\")\n",
    "        # print(f\"  input_ids shape: {batch['input_ids'].shape}\")\n",
    "        # print(f\"  attention_mask shape: {batch['attention_mask'].shape}\")\n",
    "        # print(f\"  labels shape: {batch['labels'].shape}\")\n",
    "        # print()\n",
    "\n",
    "    all_outputs = []\n",
    "\n",
    "    for ckpt_path in ckpt_paths:\n",
    "        model: LlamaForCausalLM = AutoModelForCausalLM.from_pretrained(ckpt_path, torch_dtype='auto', device_map='auto')\n",
    "        model.eval()\n",
    "\n",
    "        outputs = {}\n",
    "\n",
    "        for task_id, batch in data.items():\n",
    "            output = model(**batch, return_dict=True, output_hidden_states=True, output_attentions=True)\n",
    "            outputs[task_id] = {}\n",
    "            outputs[task_id]['hidden_states'] = np.stack([output['hidden_states'][i].detach().float().numpy() for i in range(len(output['hidden_states']))])\n",
    "            outputs[task_id]['attentions'] = np.stack([output['attentions'][i].detach().float().numpy() for i in range(len(output['attentions']))])\n",
    "\n",
    "        torch.cuda.empty_cache()\n",
    "\n",
    "        # Print the shape of the outputs\n",
    "        # for task_id, output in outputs.items():\n",
    "        #     print(f\"Task {task_id}:\")\n",
    "        #     print(f\"  hidden_states shape: {[layer.shape for layer in output['hidden_states']]}\")\n",
    "        #     print(f\"  attentions shape: {[layer.shape for layer in output['attentions']]}\")\n",
    "        #     print()\n",
    "        all_outputs.append(outputs)\n",
    "\n",
    "    return all_outputs\n",
    "\n",
    "all_outputs = get_hs_attn(ckpt_paths, tasks)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(10, 7, 75)\n",
      "(10, 6, 6)\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x350 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x350 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "all_hs_sims = []\n",
    "all_attn_sims = []\n",
    "\n",
    "for i, ckpt_path in enumerate(ckpt_paths):\n",
    "    outputs = all_outputs[i]\n",
    "    \n",
    "    num_layers = outputs['B']['hidden_states'].shape[0]\n",
    "    num_pos = outputs['B']['hidden_states'][0].shape[1]\n",
    "    hs_sim = []\n",
    "    for l in range(num_layers):\n",
    "        hs_sim.append([])\n",
    "        for pos in range(num_pos):\n",
    "            x = [outputs[task_id]['hidden_states'][l][:, pos, :].mean(0) for task_id in tasks]\n",
    "            hs_sim[-1].append(np.corrcoef(x[0], x[1])[0, 1])\n",
    "            # hs_sim[-1].append(np.linalg.norm(x[0] - x[1]) / np.linalg.norm(x[0] + x[1]))\n",
    "    all_hs_sims.append(hs_sim)\n",
    "\n",
    "    attn_sim = []\n",
    "    num_layers, _, num_attn_heads, _, _ = outputs['B']['attentions'].shape\n",
    "    for l in range(num_layers):\n",
    "        attn_sim.append([])\n",
    "        for h in range(num_attn_heads):\n",
    "            attn_sim[-1].append(\n",
    "                attn_diff := np.abs(outputs['A']['attentions'][l, h] - outputs['B']['attentions'][l, h]).mean()\n",
    "            )\n",
    "\n",
    "    all_attn_sims.append(attn_sim)\n",
    "    \n",
    "all_hs_sims = np.array(all_hs_sims)\n",
    "all_attn_sims = np.array(all_attn_sims)\n",
    "print(all_hs_sims.shape)\n",
    "print(all_attn_sims.shape)\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "\n",
    "sns.set_theme(style='whitegrid')\n",
    "plt.figure(figsize=(5, 3.5))\n",
    "# for l in range(all_hs_sims.shape[1]):\n",
    "#     plt.plot(ckpt_nums, all_hs_sims[:, l].mean(axis=(1)), label='Hidden state similarity ' + str(l))\n",
    "plt.plot(ckpt_nums, all_hs_sims[:, :, :].mean(axis=(1, 2)), label='Hidden state similarity 0')\n",
    "plt.xticks(ckpt_nums, ckpt_nums)\n",
    "plt.title(f'Correlation between tasks')\n",
    "plt.xlabel('Position')\n",
    "plt.ylabel('Correlation')\n",
    "plt.legend()\n",
    "\n",
    "plt.show()\n",
    "\n",
    "sns.set_theme(style='whitegrid')\n",
    "plt.figure(figsize=(5, 3.5))\n",
    "# for l in range(all_attn_sims.shape[1]):\n",
    "#     plt.plot(ckpt_nums, all_attn_sims[:, l].mean(1), label='Attention similarity ' + str(l) + '-' + str(h))\n",
    "plt.plot(ckpt_nums, all_attn_sims.mean(axis=(1, 2)), label='Attention similarity 0')\n",
    "plt.title(f'Attention difference between tasks')\n",
    "plt.xticks(ckpt_nums, ckpt_nums)\n",
    "plt.xlabel('Checkpoint')\n",
    "plt.ylabel('Attention difference')\n",
    "plt.legend()\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "LlamaForCausalLM(\n",
       "  (model): LlamaModel(\n",
       "    (embed_tokens): Embedding(102, 384)\n",
       "    (layers): ModuleList(\n",
       "      (0-5): 6 x LlamaDecoderLayer(\n",
       "        (self_attn): LlamaAttention(\n",
       "          (q_proj): Linear(in_features=384, out_features=384, bias=False)\n",
       "          (k_proj): Linear(in_features=384, out_features=384, bias=False)\n",
       "          (v_proj): Linear(in_features=384, out_features=384, bias=False)\n",
       "          (o_proj): Linear(in_features=384, out_features=384, bias=False)\n",
       "        )\n",
       "        (mlp): LlamaMLP(\n",
       "          (gate_proj): Linear(in_features=384, out_features=1536, bias=False)\n",
       "          (up_proj): Linear(in_features=384, out_features=1536, bias=False)\n",
       "          (down_proj): Linear(in_features=1536, out_features=384, bias=False)\n",
       "          (act_fn): SiLU()\n",
       "        )\n",
       "        (input_layernorm): LlamaRMSNorm((384,), eps=1e-06)\n",
       "        (post_attention_layernorm): LlamaRMSNorm((384,), eps=1e-06)\n",
       "      )\n",
       "    )\n",
       "    (norm): LlamaRMSNorm((384,), eps=1e-06)\n",
       "    (rotary_emb): LlamaRotaryEmbedding()\n",
       "  )\n",
       "  (lm_head): Linear(in_features=384, out_features=102, bias=False)\n",
       ")"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model: LlamaForCausalLM = AutoModelForCausalLM.from_pretrained(ckpt_paths[0], torch_dtype='auto', device_map='auto')\n",
    "model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import functools\n",
    "\n",
    "def _mean_ablation_hook(module, input_tuple, target_h, n_heads, h_dim):\n",
    "    hidden_states = input_tuple[0]\n",
    "    batch_size, seq_len, hidden_dim_ = hidden_states.shape\n",
    "\n",
    "    reshaped_states = hidden_states.view(batch_size, seq_len, n_heads, h_dim)\n",
    "\n",
    "    mean_val = torch.mean(reshaped_states[:, :, target_h, :]).item()\n",
    "\n",
    "    modified_states = reshaped_states.clone()\n",
    "    modified_states[:, :, target_h, :] = mean_val\n",
    "\n",
    "    modified_states_flat = modified_states.view(batch_size, seq_len, hidden_dim_)\n",
    "\n",
    "    # Return modified input tuple for the pre-hook\n",
    "    return (modified_states_flat,) + input_tuple[1:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "from trainers import LogitsProcessorWithLossMask\n",
    "\n",
    "def eval_batch(model, inputs):\n",
    "    kwargs = {\n",
    "        'max_new_tokens': len(inputs['labels'][0]) if model.generation_config.max_length is None else None\n",
    "    }\n",
    "    if 'loss_mask' not in inputs or (inputs['loss_mask'] == 1).all():\n",
    "        logits_processor = None\n",
    "    else:\n",
    "        logits_processor = [LogitsProcessorWithLossMask(inputs, model.generation_config.num_beams)]\n",
    "    outputs = model.generate(\n",
    "        inputs['input_ids'],\n",
    "        attention_mask=inputs['attention_mask'],\n",
    "        logits_processor=logits_processor,\n",
    "        do_sample=False,\n",
    "        use_cache=True,\n",
    "        **kwargs\n",
    "    )\n",
    "    outputs = outputs[:, len(inputs['input_ids'][0]):]\n",
    "    outputs_pad = torch.ones_like(inputs['labels']) * tokenizer.pad_token_id\n",
    "    outputs_pad[:, :outputs.shape[1]] = outputs\n",
    "    outputs = outputs_pad\n",
    "\n",
    "    # print(tokenizer.decode(inputs['input_ids'][0]))\n",
    "    # print(tokenizer.decode(outputs[0]))\n",
    "    # print(tokenizer.decode(inputs['labels'][0]))\n",
    "    accuracy = (outputs == inputs['labels']).all(1).float().mean().item()\n",
    "    # print(accuracy)\n",
    "    return accuracy\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "out/-llama-384-6-6-1024-rope-reverse_add-la=1_17-lb=1_17-reverse_add_no_carry-la=1_33-lb=1_33-reverse_add_only_carry-la=1_33-lb=1_33-SFT-seed-45/checkpoint-2000\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/<USERNAME>/miniconda3/envs/env1/lib/python3.11/site-packages/transformers/generation/utils.py:2347: UserWarning: You are calling .generate() with the `input_ids` being on a device type different than your model's device. `input_ids` is on cpu, whereas the model is on cuda. You may experience unexpected behaviors or slower generation. Please make sure that you have put `input_ids` to the correct device by calling for example input_ids = input_ids.to('cuda') before running `.generate()`.\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "out/-llama-384-6-6-1024-rope-reverse_add-la=1_17-lb=1_17-reverse_add_no_carry-la=1_33-lb=1_33-reverse_add_only_carry-la=1_33-lb=1_33-SFT-seed-45/checkpoint-4000\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/<USERNAME>/miniconda3/envs/env1/lib/python3.11/site-packages/transformers/generation/utils.py:2347: UserWarning: You are calling .generate() with the `input_ids` being on a device type different than your model's device. `input_ids` is on cpu, whereas the model is on cuda. You may experience unexpected behaviors or slower generation. Please make sure that you have put `input_ids` to the correct device by calling for example input_ids = input_ids.to('cuda') before running `.generate()`.\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "out/-llama-384-6-6-1024-rope-reverse_add-la=1_17-lb=1_17-reverse_add_no_carry-la=1_33-lb=1_33-reverse_add_only_carry-la=1_33-lb=1_33-SFT-seed-45/checkpoint-6000\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/<USERNAME>/miniconda3/envs/env1/lib/python3.11/site-packages/transformers/generation/utils.py:2347: UserWarning: You are calling .generate() with the `input_ids` being on a device type different than your model's device. `input_ids` is on cpu, whereas the model is on cuda. You may experience unexpected behaviors or slower generation. Please make sure that you have put `input_ids` to the correct device by calling for example input_ids = input_ids.to('cuda') before running `.generate()`.\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "out/-llama-384-6-6-1024-rope-reverse_add-la=1_17-lb=1_17-reverse_add_no_carry-la=1_33-lb=1_33-reverse_add_only_carry-la=1_33-lb=1_33-SFT-seed-45/checkpoint-8000\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/<USERNAME>/miniconda3/envs/env1/lib/python3.11/site-packages/transformers/generation/utils.py:2347: UserWarning: You are calling .generate() with the `input_ids` being on a device type different than your model's device. `input_ids` is on cpu, whereas the model is on cuda. You may experience unexpected behaviors or slower generation. Please make sure that you have put `input_ids` to the correct device by calling for example input_ids = input_ids.to('cuda') before running `.generate()`.\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "out/-llama-384-6-6-1024-rope-reverse_add-la=1_17-lb=1_17-reverse_add_no_carry-la=1_33-lb=1_33-reverse_add_only_carry-la=1_33-lb=1_33-SFT-seed-45/checkpoint-10000\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/<USERNAME>/miniconda3/envs/env1/lib/python3.11/site-packages/transformers/generation/utils.py:2347: UserWarning: You are calling .generate() with the `input_ids` being on a device type different than your model's device. `input_ids` is on cpu, whereas the model is on cuda. You may experience unexpected behaviors or slower generation. Please make sure that you have put `input_ids` to the correct device by calling for example input_ids = input_ids.to('cuda') before running `.generate()`.\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "out/-llama-384-6-6-1024-rope-reverse_add-la=1_17-lb=1_17-reverse_add_no_carry-la=1_33-lb=1_33-reverse_add_only_carry-la=1_33-lb=1_33-SFT-seed-45/checkpoint-12000\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/<USERNAME>/miniconda3/envs/env1/lib/python3.11/site-packages/transformers/generation/utils.py:2347: UserWarning: You are calling .generate() with the `input_ids` being on a device type different than your model's device. `input_ids` is on cpu, whereas the model is on cuda. You may experience unexpected behaviors or slower generation. Please make sure that you have put `input_ids` to the correct device by calling for example input_ids = input_ids.to('cuda') before running `.generate()`.\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "out/-llama-384-6-6-1024-rope-reverse_add-la=1_17-lb=1_17-reverse_add_no_carry-la=1_33-lb=1_33-reverse_add_only_carry-la=1_33-lb=1_33-SFT-seed-45/checkpoint-14000\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/<USERNAME>/miniconda3/envs/env1/lib/python3.11/site-packages/transformers/generation/utils.py:2347: UserWarning: You are calling .generate() with the `input_ids` being on a device type different than your model's device. `input_ids` is on cpu, whereas the model is on cuda. You may experience unexpected behaviors or slower generation. Please make sure that you have put `input_ids` to the correct device by calling for example input_ids = input_ids.to('cuda') before running `.generate()`.\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "out/-llama-384-6-6-1024-rope-reverse_add-la=1_17-lb=1_17-reverse_add_no_carry-la=1_33-lb=1_33-reverse_add_only_carry-la=1_33-lb=1_33-SFT-seed-45/checkpoint-16000\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/<USERNAME>/miniconda3/envs/env1/lib/python3.11/site-packages/transformers/generation/utils.py:2347: UserWarning: You are calling .generate() with the `input_ids` being on a device type different than your model's device. `input_ids` is on cpu, whereas the model is on cuda. You may experience unexpected behaviors or slower generation. Please make sure that you have put `input_ids` to the correct device by calling for example input_ids = input_ids.to('cuda') before running `.generate()`.\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "out/-llama-384-6-6-1024-rope-reverse_add-la=1_17-lb=1_17-reverse_add_no_carry-la=1_33-lb=1_33-reverse_add_only_carry-la=1_33-lb=1_33-SFT-seed-45/checkpoint-18000\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/<USERNAME>/miniconda3/envs/env1/lib/python3.11/site-packages/transformers/generation/utils.py:2347: UserWarning: You are calling .generate() with the `input_ids` being on a device type different than your model's device. `input_ids` is on cpu, whereas the model is on cuda. You may experience unexpected behaviors or slower generation. Please make sure that you have put `input_ids` to the correct device by calling for example input_ids = input_ids.to('cuda') before running `.generate()`.\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "out/-llama-384-6-6-1024-rope-reverse_add-la=1_17-lb=1_17-reverse_add_no_carry-la=1_33-lb=1_33-reverse_add_only_carry-la=1_33-lb=1_33-SFT-seed-45/checkpoint-20000\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/<USERNAME>/miniconda3/envs/env1/lib/python3.11/site-packages/transformers/generation/utils.py:2347: UserWarning: You are calling .generate() with the `input_ids` being on a device type different than your model's device. `input_ids` is on cpu, whereas the model is on cuda. You may experience unexpected behaviors or slower generation. Please make sure that you have put `input_ids` to the correct device by calling for example input_ids = input_ids.to('cuda') before running `.generate()`.\n",
      "  warnings.warn(\n"
     ]
    }
   ],
   "source": [
    "from data import tokenization_eval\n",
    "\n",
    "data = {}\n",
    "for task_id, task_name in tasks.items():\n",
    "    batch = []\n",
    "    rng = np.random.default_rng(42)\n",
    "    for i in range(1024):\n",
    "        prompt, target, loss_mask = task_registry[task_name](rng=rng, la=[16, 33])\n",
    "        if loss_mask is None:\n",
    "            loss_mask = [1] * len(target)\n",
    "        ex = {'prompt': [prompt], 'target': [target], 'loss_mask': [loss_mask]}\n",
    "        ex = add_special_tokens(ex, tokenizer, task_id=task_id)\n",
    "        ex = tokenization_eval(ex, tokenizer)\n",
    "        batch += [{key: value[i] for key, value in ex.items()} for i in range(len(ex['eval_input_ids']))]\n",
    "    batch = collator(batch)\n",
    "    data[task_id] = batch\n",
    "\n",
    "eval_results = {task_id: [] for task_id in tasks}\n",
    "\n",
    "for i, ckpt_path in enumerate(ckpt_paths):\n",
    "    print(ckpt_path)\n",
    "    model = LlamaForCausalLM.from_pretrained(ckpt_path, torch_dtype='auto', device_map='auto')\n",
    "    model.generation_config.pad_token_id = tokenizer.pad_token_id\n",
    "    model.generation_config.eos_token_id = tokenizer.eos_token_id\n",
    "    model.eval()\n",
    "\n",
    "    for task_id, batch in data.items():\n",
    "        accuracy = eval_batch(model, batch)\n",
    "        eval_results[task_id].append(accuracy)\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAdgAAAFmCAYAAADOGYucAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjAsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvlHJYcgAAAAlwSFlzAAAPYQAAD2EBqD+naQAAeK5JREFUeJzt3XlYVNX/B/D3zMAMwzIsssgioiA7CiqyuO+WWpmZlltlappLmWaWmaallmapZW6Vtmjuv69bZe4LuC+ooLIJAsrOAAPMdn5/IBMjiwzMcAf8vJ7HR71z7533rJ855557Lo8xxkAIIYQQveJzHYAQQghpjqjAEkIIIQZABZYQQggxACqwhBBCiAFQgSWEEEIMgAosIYQQYgBUYAkhhBADoAJLCCGEGAAVWEIIIcQAqMASbN26FT4+PhgyZAjXUZqtBw8eYNKkSejSpQt8fHzwxRdf1Ljujz/+iH///degefbs2QMfHx/ExMQY9H6eJj4+HmvWrMGDBw/0tk+uHtuaNWvg4+OD3NzcRr1fAOjTpw8++uijem27f/9+/PLLL/oNRAAAJlwHINzbvXs3AODevXu4fv06OnTowHGi5mfp0qW4fv06vvzyS9jb28PBwaHGddevX4+BAweiX79+jZiQG/Hx8Vi7di26dOkCNzc3ruM0WWvXroWlpWW9tj1w4ADu3buHN954Q7+hCLVgn3UxMTGIi4tDr169AAC7du3iNlAtSkpKuI5Qb/fu3UP79u3Rr18/BAcHw9XVletIpBnx9/eHu7s71zHIE6jAPuMqCuoHH3yAkJAQHDx4sNpC9ujRI3z66afo2bMnAgMD0a1bN8yYMQPZ2dmadaRSKZYtW4a+ffsiMDAQERERmDhxIhISEgAA58+fh4+PD86fP6+17wcPHsDHxwd79uzRLPvoo48QEhKCO3fu4K233kJISIjmF/bZs2cxZcoU9OjRA0FBQejfvz8WLFhQbddcQkICZs2ahcjISAQGBqJXr1748MMPIZfL8eDBA/j7+2P9+vVVtrt48SJ8fHxw+PDhWp+/9PR0zJ49GxEREQgMDMRzzz2Hn376CWq1Wusx379/H6dOnYKPjw98fHxq7BL18fGBTCbD3r17NeuOHTsWAJCbm4uFCxfi+eefR0hICCIiIjBu3DhcunSpyn7++OMPvPDCCwgJCUFISAgGDRqEb775ptbHkpmZiZdffhkDBgxAcnIyACA1NRXvv/8+unXrhsDAQERGRmL8+PGIjY2tdV8xMTF4//330adPH7Rv3x59+vTBrFmzkJaWpllnz549mDlzJgBg3Lhxmsdb+X1Qndpe08qKi4vx2WefISwsDGFhYZg2bRoePXpUZX+HDh3CyJEjERwcjJCQEEyYMAG3b9+ust7169fxzjvvICwsDEFBQejXr1+tXf0VWfv27YsRI0YgJycHADB27FgMGTIEly5dwquvvor27duje/fu+Pbbb6FSqbS2z8/Px8KFC9G9e3cEBgaib9++WLVqVZXH+mQXccX77sCBA1i1ahW6deuGjh074o033kBiYqJmvbFjx+LEiRNIS0vTPP8+Pj6a2+vzPiL/oS7iZ1hpaSkOHjyIoKAgeHt7Y/jw4Zg/fz7++usvDBs2TLPeo0ePMHz4cCiVSrzzzjvw8fFBXl4ezpw5g4KCAtjb26OoqAivv/460tLS8Pbbb6NDhw6QyWS4ePEisrKy4OnpqXM+hUKBKVOmYNSoUZg4caLmyyclJQUhISEYMWIErKyskJaWhp9//hmvv/469u/fD1NTUwBAXFwcXnvtNdja2mLGjBlo3bo1srKycOzYMcjlcri5uaFPnz7Yvn073n77bQgEAs19//bbb3B0dET//v1rzJebm4tRo0ZBoVBg5syZcHV1xYkTJ7B8+XKkpKRg4cKFCAgIwJ9//olp06ahVatWmDt3LgDA0dGx2n3++eefGD9+PMLCwjB16lQA0HT95efnAwCmTZsGe3t7yGQyHDlyBGPHjsUvv/yCsLAwAMDBgwexaNEijB07FnPnzgWfz8f9+/cRHx9f42O5e/cuJk2ahJYtW2L79u2ws7MDAEycOBFqtRpz5syBi4sL8vLycPXqVUil0lpfu7S0NLRp0waDBw+GtbU1srKysG3bNrzyyis4ePAg7Ozs0KtXL8yaNQvffPMNFixYgICAAACotSX2tNdUKBRq1p0/fz569eqFlStXIiMjA19//TXmzJmDrVu3atb58ccf8e233+Lll1/GlClToFAosHnzZowePRo7d+6El5cXAOD06dOYMmUK2rZti48++gjOzs5IS0vD2bNna8x64cIFTJs2DZ07d8bKlSshFos1t2VlZeH999/HpEmTMGPGDJw4cQLr1q2DVCrFggULAABlZWUYN24c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",
      "text/plain": [
       "<Figure size 500x350 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(5, 3.5))\n",
    "for task_id, accuracies in eval_results.items():\n",
    "    plt.plot(ckpt_nums, accuracies, label=task_id)\n",
    "plt.title(f'Accuracy of tasks at checkpoints')\n",
    "plt.xticks(ckpt_nums, ckpt_nums)\n",
    "plt.xlabel('Checkpoint')\n",
    "plt.ylabel('Accuracy')\n",
    "plt.legend()\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "out/-llama-384-6-6-1024-rope-reverse_add-la=1_17-lb=1_17-reverse_add_no_carry-la=1_33-lb=1_33-reverse_add_only_carry-la=1_33-lb=1_33-SFT-seed-45/checkpoint-2000\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/<USERNAME>/miniconda3/envs/env1/lib/python3.11/site-packages/transformers/generation/utils.py:2347: UserWarning: You are calling .generate() with the `input_ids` being on a device type different than your model's device. `input_ids` is on cpu, whereas the model is on cuda. You may experience unexpected behaviors or slower generation. Please make sure that you have put `input_ids` to the correct device by calling for example input_ids = input_ids.to('cuda') before running `.generate()`.\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "out/-llama-384-6-6-1024-rope-reverse_add-la=1_17-lb=1_17-reverse_add_no_carry-la=1_33-lb=1_33-reverse_add_only_carry-la=1_33-lb=1_33-SFT-seed-45/checkpoint-4000\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/<USERNAME>/miniconda3/envs/env1/lib/python3.11/site-packages/transformers/generation/utils.py:2347: UserWarning: You are calling .generate() with the `input_ids` being on a device type different than your model's device. `input_ids` is on cpu, whereas the model is on cuda. You may experience unexpected behaviors or slower generation. Please make sure that you have put `input_ids` to the correct device by calling for example input_ids = input_ids.to('cuda') before running `.generate()`.\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "out/-llama-384-6-6-1024-rope-reverse_add-la=1_17-lb=1_17-reverse_add_no_carry-la=1_33-lb=1_33-reverse_add_only_carry-la=1_33-lb=1_33-SFT-seed-45/checkpoint-6000\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/<USERNAME>/miniconda3/envs/env1/lib/python3.11/site-packages/transformers/generation/utils.py:2347: UserWarning: You are calling .generate() with the `input_ids` being on a device type different than your model's device. `input_ids` is on cpu, whereas the model is on cuda. You may experience unexpected behaviors or slower generation. Please make sure that you have put `input_ids` to the correct device by calling for example input_ids = input_ids.to('cuda') before running `.generate()`.\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "out/-llama-384-6-6-1024-rope-reverse_add-la=1_17-lb=1_17-reverse_add_no_carry-la=1_33-lb=1_33-reverse_add_only_carry-la=1_33-lb=1_33-SFT-seed-45/checkpoint-8000\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/<USERNAME>/miniconda3/envs/env1/lib/python3.11/site-packages/transformers/generation/utils.py:2347: UserWarning: You are calling .generate() with the `input_ids` being on a device type different than your model's device. `input_ids` is on cpu, whereas the model is on cuda. You may experience unexpected behaviors or slower generation. Please make sure that you have put `input_ids` to the correct device by calling for example input_ids = input_ids.to('cuda') before running `.generate()`.\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "out/-llama-384-6-6-1024-rope-reverse_add-la=1_17-lb=1_17-reverse_add_no_carry-la=1_33-lb=1_33-reverse_add_only_carry-la=1_33-lb=1_33-SFT-seed-45/checkpoint-10000\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/<USERNAME>/miniconda3/envs/env1/lib/python3.11/site-packages/transformers/generation/utils.py:2347: UserWarning: You are calling .generate() with the `input_ids` being on a device type different than your model's device. `input_ids` is on cpu, whereas the model is on cuda. You may experience unexpected behaviors or slower generation. Please make sure that you have put `input_ids` to the correct device by calling for example input_ids = input_ids.to('cuda') before running `.generate()`.\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "out/-llama-384-6-6-1024-rope-reverse_add-la=1_17-lb=1_17-reverse_add_no_carry-la=1_33-lb=1_33-reverse_add_only_carry-la=1_33-lb=1_33-SFT-seed-45/checkpoint-12000\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/<USERNAME>/miniconda3/envs/env1/lib/python3.11/site-packages/transformers/generation/utils.py:2347: UserWarning: You are calling .generate() with the `input_ids` being on a device type different than your model's device. `input_ids` is on cpu, whereas the model is on cuda. You may experience unexpected behaviors or slower generation. Please make sure that you have put `input_ids` to the correct device by calling for example input_ids = input_ids.to('cuda') before running `.generate()`.\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "out/-llama-384-6-6-1024-rope-reverse_add-la=1_17-lb=1_17-reverse_add_no_carry-la=1_33-lb=1_33-reverse_add_only_carry-la=1_33-lb=1_33-SFT-seed-45/checkpoint-14000\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/<USERNAME>/miniconda3/envs/env1/lib/python3.11/site-packages/transformers/generation/utils.py:2347: UserWarning: You are calling .generate() with the `input_ids` being on a device type different than your model's device. `input_ids` is on cpu, whereas the model is on cuda. You may experience unexpected behaviors or slower generation. Please make sure that you have put `input_ids` to the correct device by calling for example input_ids = input_ids.to('cuda') before running `.generate()`.\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "out/-llama-384-6-6-1024-rope-reverse_add-la=1_17-lb=1_17-reverse_add_no_carry-la=1_33-lb=1_33-reverse_add_only_carry-la=1_33-lb=1_33-SFT-seed-45/checkpoint-16000\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/<USERNAME>/miniconda3/envs/env1/lib/python3.11/site-packages/transformers/generation/utils.py:2347: UserWarning: You are calling .generate() with the `input_ids` being on a device type different than your model's device. `input_ids` is on cpu, whereas the model is on cuda. You may experience unexpected behaviors or slower generation. Please make sure that you have put `input_ids` to the correct device by calling for example input_ids = input_ids.to('cuda') before running `.generate()`.\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "out/-llama-384-6-6-1024-rope-reverse_add-la=1_17-lb=1_17-reverse_add_no_carry-la=1_33-lb=1_33-reverse_add_only_carry-la=1_33-lb=1_33-SFT-seed-45/checkpoint-18000\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/<USERNAME>/miniconda3/envs/env1/lib/python3.11/site-packages/transformers/generation/utils.py:2347: UserWarning: You are calling .generate() with the `input_ids` being on a device type different than your model's device. `input_ids` is on cpu, whereas the model is on cuda. You may experience unexpected behaviors or slower generation. Please make sure that you have put `input_ids` to the correct device by calling for example input_ids = input_ids.to('cuda') before running `.generate()`.\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "out/-llama-384-6-6-1024-rope-reverse_add-la=1_17-lb=1_17-reverse_add_no_carry-la=1_33-lb=1_33-reverse_add_only_carry-la=1_33-lb=1_33-SFT-seed-45/checkpoint-20000\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/<USERNAME>/miniconda3/envs/env1/lib/python3.11/site-packages/transformers/generation/utils.py:2347: UserWarning: You are calling .generate() with the `input_ids` being on a device type different than your model's device. `input_ids` is on cpu, whereas the model is on cuda. You may experience unexpected behaviors or slower generation. Please make sure that you have put `input_ids` to the correct device by calling for example input_ids = input_ids.to('cuda') before running `.generate()`.\n",
      "  warnings.warn(\n"
     ]
    }
   ],
   "source": [
    "from data import tokenization_eval\n",
    "\n",
    "data = {}\n",
    "for task_id, task_name in tasks.items():\n",
    "    batch = []\n",
    "    rng = np.random.default_rng(42)\n",
    "    for i in range(1024):\n",
    "        prompt, target, loss_mask = task_registry[task_name](rng=rng, la=[6, 33])\n",
    "        if loss_mask is None:\n",
    "            loss_mask = [1] * len(target)\n",
    "        ex = {'prompt': [prompt], 'target': [target], 'loss_mask': [loss_mask]}\n",
    "        ex = add_special_tokens(ex, tokenizer, task_id=task_id)\n",
    "        ex = tokenization_eval(ex, tokenizer)\n",
    "        batch += [{key: value[i] for key, value in ex.items()} for i in range(len(ex['eval_input_ids']))]\n",
    "    batch = collator(batch)\n",
    "    data[task_id] = batch\n",
    "    \n",
    "head_dim = model.config.hidden_size // model.config.num_attention_heads\n",
    "ablation_results = np.zeros((len(ckpt_paths), len(tasks), model.config.num_hidden_layers, model.config.num_attention_heads))\n",
    "\n",
    "for i, ckpt_path in enumerate(ckpt_paths):\n",
    "    print(ckpt_path)\n",
    "    model = LlamaForCausalLM.from_pretrained(ckpt_path, torch_dtype='auto', device_map='auto')\n",
    "    model.generation_config.pad_token_id = tokenizer.pad_token_id\n",
    "    model.generation_config.eos_token_id = tokenizer.eos_token_id\n",
    "    model.eval()\n",
    "\n",
    "    for j, (task_id, inputs) in enumerate(data.items()):\n",
    "        for layer in range(model.config.num_hidden_layers):\n",
    "            for head in range(model.config.num_attention_heads):\n",
    "                specific_ablation_hook = functools.partial(\n",
    "                    _mean_ablation_hook,\n",
    "                    target_h=head,\n",
    "                    n_heads=model.config.num_attention_heads,\n",
    "                    h_dim=head_dim\n",
    "                )\n",
    "                target_module = model.model.layers[layer].self_attn.o_proj\n",
    "                handle = target_module.register_forward_pre_hook(specific_ablation_hook)\n",
    "                \n",
    "                accuracy = eval_batch(model, inputs)\n",
    "                ablation_results[i, j, layer, head] = accuracy\n",
    "\n",
    "                handle.remove()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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vvgC77zzDvh8fpvnmK1su3fvxsMPP6z2HBtKttbW1jbvCZFIBEZxQtdj2SZNmgQejwepVMrq563y/XBvtvZeb/dDhVhHLl26BCsrKwwYMAB5eXloaWmBu7u72j6enp4AALFYrPb3vft5eHigvr4eJSUlqv3c3NzUioTyeMpj3OvPP/9ERkYGXnrppTa3sZXv2rVr8Pb2xtdff42wsDAMHToU8+fPR3p6Oqu5AOCxxx5DVlYWfvzxR0gkEhQUFOCTTz6Bh4cHwsLCWM93N7ZyiMVieHh4qO3D4/HA5/M7zQsAcrkcV65cUbt/T+TjcDhwcXFpk2/9+vUICAjA+PHj283LRjapVIq0tDQMHDgQb775JoKDgxEaGoo33ngDVVVVrGYDgDlz5uD333/H2bNnUV9fj5SUFHz//feYMWMGzMzMeiybQCCAmZkZBAIBq5+3HWVr7/V2P1SIdSAlJQV79uzBwoULwePxUFNTA0DxbfFuyp+Vt0skEggEApiYmKjtpzybqK6uVu137zdR5fGUx7pbY2MjYmNj8frrr8Pc3LzN7WzlKysrw+nTp5GQkIAPP/wQX331FRobG/HMM89AIpGw+ryNGDECGzduxJdffokRI0ZgwoQJyM/Px/fffw+BQMDq83YvtnJIJJI2jwkAXC6307wA8OOPPyI7OxvPPPOM2vF6It+9+6Wnp2P37t145513OszLRrbq6mq0trZi69atqK2txddff4333nsPZ8+exeuvv85qNgB48cUXsXDhQjz77LMIDQ3FY489Bm9vb/z73//u0WwpKSmQSCRwdnZm9fO2q89bVxhptDdpo6ysDMuXL0dgYCAWL16sdtu936ja297ePsomkvvt19H2zZs3Y8CAAZg5c2an2Xs6H8MwaGhowFdffQUvLy8AQEBAACZMmIBffvkFoaGhrOQCFM1Wb775JmbNmoXo6GjU1dXhm2++weLFi/G///1P7QsNW7/Xru7T0znut9+FCxfw2Wef4dlnn8WIESPuez9d52MYRrUfwzD497//jXnz5rU5m+nKsfWdDVB8kG/YsEH1BdDMzAzLli1DcnIygoKCWMkGADt27MB///tfrFy5EgEBAcjOzsb//d//YfXq1fjkk086Pbausik/b83MzNp0uRnK++He560r6Iy4G2pra7F48WKYmJhg8+bNqr4m5Tese78VKYf5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",
      "text/plain": [
       "<Figure size 500x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "\n",
    "# for i, ckpt_path in enumerate(ckpt_paths):\n",
    "#     for j, (task_id, inputs) in enumerate(data.items()):\n",
    "#         plt.figure(figsize=(5, 4))\n",
    "#         sns.heatmap(\n",
    "#             ablation_results[i, j],\n",
    "#             annot=True,\n",
    "#             xticklabels=range(model.config.num_attention_heads),\n",
    "#             yticklabels=range(model.config.num_hidden_layers),\n",
    "#             ax=plt.gca()\n",
    "#         )\n",
    "#         plt.gca().invert_yaxis()  # Reverse the y-axis\n",
    "#         plt.title(f'Checkpoint {ckpt_nums[i]} - Task {task_id}')\n",
    "#         plt.xlabel('Attention Head')\n",
    "#         plt.ylabel('Layer')\n",
    "#         plt.tight_layout()\n",
    "#         plt.show()\n",
    "\n",
    "eval_results = np.array([eval_results[task_id] for task_id in tasks])\n",
    "\n",
    "plt.figure(figsize=(5, 4))\n",
    "plt.plot(ckpt_nums, np.abs(\n",
    "    (ablation_results[:, 0] - eval_results[0, None, None].T) -\n",
    "    (ablation_results[:, 1] - eval_results[1, None, None].T)\n",
    ").mean(axis=(1, 2)), label='A-B')\n",
    "plt.xticks(ckpt_nums)\n",
    "plt.xlabel('Checkpoint')\n",
    "plt.ylabel('Mean ablation map difference')\n",
    "plt.show()\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "env1",
   "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.11.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
