{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T16:40:11.046232Z",
     "iopub.status.busy": "2025-09-24T16:40:11.046136Z",
     "iopub.status.idle": "2025-09-24T16:40:13.037237Z",
     "shell.execute_reply": "2025-09-24T16:40:13.036673Z"
    }
   },
   "outputs": [],
   "source": [
    "# --- MATS causal interventions + hydra-style analysis (Llama-3.2-3B) ---\n",
    "\n",
    "import os, math, json, random, gc, pathlib\n",
    "from dataclasses import dataclass\n",
    "from typing import Dict, List, Tuple, Optional, Literal\n",
    "\n",
    "import numpy as np\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from transformers import AutoTokenizer, AutoModelForCausalLM\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "SEED = 123\n",
    "random.seed(SEED); np.random.seed(SEED); torch.manual_seed(SEED)\n",
    "\n",
    "\n",
    "\n",
    "# Evaluation settings\n",
    "DEVICE = \"cuda\" if torch.cuda.is_available() else \"cpu\"\n",
    "DTYPE  = torch.bfloat16\n",
    "HF_TOKEN   = os.environ.get(\"HF_TOKEN\")\n",
    "GEN_MAX_NEW_TOKENS = 64\n",
    "TEMPERATURE = 0.0\n",
    "TOP_K = None\n",
    "\n",
    "# Anchor positions we evaluate hydra/kl at:\n",
    "EVAL_POS = \"last\"   # 'last' or 'first_code' (we compute first code token index)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T16:40:13.040743Z",
     "iopub.status.busy": "2025-09-24T16:40:13.040575Z",
     "iopub.status.idle": "2025-09-24T16:40:13.046147Z",
     "shell.execute_reply": "2025-09-24T16:40:13.045779Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['cpp', 'c', ' def', ' c', ' //', ' #', 'python', ' public', 'def', 'public', 'C', 'java', ' class', ' C', 'class', ' import', 'import', '#', 'function', 'void', '//', 'bash', ' function', ' void', ' int', ' \\n', ' const', ' cpp', ' python', '#include', ' ', 'include', ' Input', 'Write', 'const', ' Write', 'string', 'int', 'The', '$', ' string', 'from', 'bool', 'if', '@', ' from', ' char', 'private', '    ', 'Given', 'char', ' The', 'Python', ' /*', ' java', ' bool', ' @', ' $', 'var', '<|end_of_text|>', 'package', '  ', 'I', ' ```', '1', 'input', ' if', ' ```\\n', 'javascript', ' Given', 'Input', 'find', ' private', 'Solution', 'In', ' input', ' *', 'n', '`\\n', ' std', 'h', 'x', ' include', '<', 'std', '   ', 'sh', '{', ' In', 'js', ' Solution', ' https', ' var', 'https', '[', 'p', ' Find', 'This', ' Use', ' Python', 'k', ' A', 'sum', '*', 'array', ' <', ' I', 'ruby', 'for', ' n', 'Please', 'diff', 'using', ' Please', ' [', 'You', ' (', ' static', 'text', 'A', ' This', 'write', '(', 'Create', ' package', 'Find', 'py', ' Create', 'func', '/*', 'j', 'html', '#!/', ' You', ' Function', 'static', ' bash', 'tree', ' for', '!', 'cs', ' x', ' array', 'go', ' If', 'my', '/', ' From', 'CPP', ' \"', 'f', '%', '\\xa0', 's', 'use', ' using', 'H', 'Java', ' Enter', '        ', 'Use', ' \\n\\n', 'graph', ' return', ' write', 'i', ' let', ' h', 'Enter', 'while', 'boolean', 'Sample', ' vector', 'Your', 'in', 'shell', 'If', 'Note', '  \\n', ' ##', 'P', 'vector', 'S', ' Def', 'y', 'long', 'Example', 'Function', 'test', 'nim', 'swift', 'txt', 'struct', '2', ' typedef', ' {', 'Cpp', '/**\\n', ' Note', 'g', ' javascript', 'a', ' Here', 'create', ' print', ' Output', 'no', ' Example', ' >>>', 'cat', 'val', ' Problem', 'return', 'output', 'let', '      ', 'Let', '       ', '0', ' struct', ' find', 'rust', 'My', 'php', ' -', ' Sample', 'scala', 'sub', 'D', ' Task', 'Go', 'solution', 'Output', ' /**\\n', 'print', ' /**', 'd', 'l', '\"', '.', ' Consider', 'String', 'double', ' %', 'task', ' solution', 'sort', ' No', ' Java', ' sum', ' /', 'Problem', ' f', 'Accepted', 'list', ' ###', ' k', ' Accepted', 'B', ' val', 'short', ' To', 'Here', '\\n\\n\\n', '     ', ' tree', '##', ' --', 'git', ' Go', ' Expected', 'Implement', ' Your', ' enter', ' a', ' l', '            ', ' Include', 'dart', ' __', '\\u200b', ' double', ' Using', ' use', ' cin', ' long', '-', 'From', 'pre', 'count', '\\xa0\\n', ' p', ' while', 't', '#!', 'How', ' boolean', 'No', 'pair', ' \\xa0']\n",
      "['python', ' def', 'def', ' #', '#', ' python', ' import', 'class', ' class', 'c', 'import', 'cpp', ' c', ' //', 'Python', 'public', ' ', ' public', 'from', '//', 'java', ' from', 'function', ' function', 'bash', ' Python', ' \\n', 'C', '  ', 'py', 'Write', 'void', '    ', ' C', 'The', '<|end_of_text|>', ' The', ' Write', 'if', 'string', '   ', ' Input', '@', '$', 'private', 'var', 'package', 'javascript', ' const', 'const', 'Given', 'int', 'include', 'Solution', ' $', ' string', '#!/', 'In', 'input', ' if', ' ```', ' In', ' >>>', 'x', ' int', '1', '[', ' A', 'Input', 'I', 'A', 'bool', '*', ' Given', ' /*', '`\\n', 'char', 'h', 'n', ' private', ' list', ' *', ' Solution', 'list', ' print', 'ruby', ' void', 'find', 'sh', ' Please', '{', ' @', ' var', '<', ' You', ' java', ' ```\\n', ' input', 'js', 'You', ' ##', 'print', 'write', ' (', 'Sample', 'for', '##', 'https', '        ', ' Create', ' [', ' Find', 'Please', ' This', '/*', 'html', ' Use', '(', 'Create', 'text', '       ', 'This', ' n', ' https', '/', 'using', ' Enter', '      ', 'H', ' From', ' x', ' Sample', 'P', 'my', ' \\n\\n', '>>>', ' Function', ' for', '\\xa0', '%', ' return', 'long', '#include', ' package', 'use', ' char', ' bool', 'test', ' Example', ' write', 'Find', ' I', '2', 'sum', ' Note', ' ###', 'Example', 'Enter', 'p', 'create', ' If', ' \"', 'struct', 'tree', 'go', 'in', 'k', ' <', 'git', 'func', 'Note', 'static', ' py', 'My', 'j', '\\n\\n\\n', '?', '###', '     ', 'S', '/**\\n', '!', ' bash', 'Your', ' cpp', ' Def', 'graph', 'diff', '            ', 'Use', 's', ' include', '  \\n', 'let', ' let', 'nim', 'Output', ' Output', ' using', '.', ' Implement', 'a', 'short', 'Java', './', 'pass', ' Expected', 'If', 'i', 'l', 'List', 'while', ' javascript', 'scala', 'txt', 'sample', ' find', 'f', 'num', 'y', ' List', '>', ' /', 'Let', ' static', 'return', 'String', '/*\\n', ' my', 'Function', '\"', 'Accepted', 'sub', 'cs', ' solution', 'array', ' Here', ' Your', 'str', 'Implement', 'sort', 'data', 'From', 'assert', ' test', ' l', '           ', '\\u200b', 'shell', ' create', ' No', 'cat', 'swift', ' long', '          ', 'val', ' use', '#!', 'g', ' raise', ' h', ' enter', ' Using', 'D', ' For', ' To', ' a', ' Accepted', 'boolean', ' Let', 'solution', 'output', 'grid', ' H', ' My', ' --', ' /**\\n', '              ', '3', ' Problem', 'Py', ' struct', ' tree', 'Expected', '0', '         ', ' Consider', ' k', 'is', ' Test', \"'\", 'Go', 'lst', ' sort', ' /**', 'Here', 'task', ' try', 'Using', ' Task']\n"
     ]
    }
   ],
   "source": [
    "\n",
    "# Examples of what token set type is used\n",
    "# token_list_value = {\n",
    "#     \"cpp_top\": [\"std\", \"int\", \";\", \"{\", \"}\", \"[i\", \"long\", \"return\", \"<<\", \">>\"],\n",
    "#     \"python_top\": [\":\", \"None\", \"def\", \"print\", \"==\", \"len\", \"range\", \"str\", \",\", \"):\"],\n",
    "#     \"science\": [\"energy\", \"water\", \"cells\", \"system\", \"body\", \"blod\", \"carbon\", \"molecules\", \"light\", \"atoms\"],\n",
    "#     \"medical\": [\"cause\", \"options\", \"clinical\", \"patient\", \"blood\", \"symptoms\", \"disease\", \"diagnosis\", \"pain\", \"condition\"],\n",
    "#     \"finance\": [\"company\", \"total\", \"capital\", \"share\", \"tax\", \"assets\", \"total\", \"rate\", \"ratio\", \"value\"],\n",
    "#     \"math\": [\"total\", \"many\", \"number\", \"per\", \"cost\", \"times\", \"find\", \"one\", \"amount\", \"money\"]\n",
    "# }\n",
    "def tok(s: str):\n",
    "    return tokenizer(s, return_tensors=\"pt\").to(DEVICE)\n",
    "\n",
    "def untok(s: int):\n",
    "    return tokenizer.decode(s)\n",
    "# [tok(i)['input_ids'][0][1].item() for i in config_dict['cpp-python'].a.token_set]\n",
    "# token_list = {key: [tok(i)['input_ids'][0][1].item() for i in value] for key, value in token_list_value.items()}\n",
    "\n",
    "# print(token_list) \n",
    "class Language:\n",
    "    def __init__(self, name: str, token_set: list[str] | None = None):\n",
    "        self.name = name\n",
    "        if token_set is None:\n",
    "            self.token_set = self.load_tokens()\n",
    "        else:\n",
    "            self.token_set = token_set\n",
    "        \n",
    "    def load_tokens(self):\n",
    "        with open(\"token_sets/tokens.json\", 'r') as f:\n",
    "            data = json.load(f)\n",
    "            \n",
    "        if self.name == \"cpp_top\":\n",
    "            print(data[\"cpp_top\"])\n",
    "            return data[\"cpp_top\"]\n",
    "        if self.name == \"python_top\":\n",
    "            print(data[\"python_top\"])\n",
    "            return data[\"python_top\"]\n",
    "        return data[self.name]\n",
    "    # def load_specific(self):\n",
    "    #     return token_list[self.name]\n",
    "\n",
    "class DatasetPairConfig:\n",
    "    def __init__(self, lang_a: str, lang_b: str, file_path: str):\n",
    "        self.a = Language(lang_a)\n",
    "        self.b = Language(lang_b)\n",
    "        self.prompts = self.load_file(file_path)\n",
    "        \n",
    "    def load_file(self, file_path):\n",
    "        with open(file_path, 'r') as f:\n",
    "            data = json.load(f)\n",
    "        prompts = []\n",
    "        for element in data:\n",
    "            prompts.append((element[self.a.name], element[self.b.name]))\n",
    "        return prompts\n",
    "        \n",
    "        \n",
    "# CPP_TOKENS = {\"def\", \"import\", \":\", \"pass\"}     # Python-ish indicators\n",
    "# PYTHON_TOKENS = {\";\", \"::\", \"std\", \"#\"}            # C++-ish indicators; '#' approximates #include\n",
    "\n",
    "config_dict = {\n",
    "    \"cpp-python\": DatasetPairConfig(\"cpp_top\", \"python_top\", \"prompt_set/cpp_python_add.json\"),\n",
    "    # \"sci-math\": DatasetPairConfig(\"science\", \"math\", \"prompt_set/sci_math_prompts.json\"),\n",
    "    # \"medical-finance\": DatasetPairConfig(\"medical\", \"finance\", \"prompt_set/fin_med_prompts.json\"),\n",
    "}\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T16:40:13.067081Z",
     "iopub.status.busy": "2025-09-24T16:40:13.066708Z",
     "iopub.status.idle": "2025-09-24T16:40:13.089936Z",
     "shell.execute_reply": "2025-09-24T16:40:13.089523Z"
    }
   },
   "outputs": [],
   "source": [
    "# ---------------- Utilities ----------------\n",
    "def tok(s: str):\n",
    "    return tokenizer(s, return_tensors=\"pt\").to(DEVICE)\n",
    "\n",
    "def generate_logits(prompt: str, max_new_tokens=0):\n",
    "    \"\"\"Return logits over next token for the prompt (no generation if max_new_tokens=0).\"\"\"\n",
    "    with torch.no_grad():\n",
    "        enc = tok(prompt)\n",
    "        out = model(**enc)\n",
    "        logits = out.logits  # [B, T, V]\n",
    "    return enc, logits\n",
    "\n",
    "def pick_eval_index(tokenizer, input_ids: torch.Tensor, text: str, mode: str) -> int:\n",
    "    # mode 'last': last token in the prompt; 'first_code': first token after a code marker\n",
    "    if mode == \"last\":\n",
    "        return input_ids.shape[1] - 1\n",
    "    if mode == \"first_code\":\n",
    "        # Heuristic: find \"```\" or a language marker in the prompt text\n",
    "        idx = text.find(\"```\")\n",
    "        if idx < 0: return input_ids.shape[1] - 1\n",
    "        # tokenize up to the backticks and use its length - 1\n",
    "        prefix = text[:idx+3]\n",
    "        with torch.no_grad():\n",
    "            ids = tokenizer(prefix, return_tensors=\"pt\").to(DEVICE)[\"input_ids\"]\n",
    "        return min(ids.shape[1]-1, input_ids.shape[1]-1)\n",
    "    return input_ids.shape[1] - 1\n",
    "\n",
    "def kl_divergence(p_logits, q_logits):\n",
    "    # KL(p || q) at a single position; stable softmax\n",
    "    p = F.log_softmax(p_logits, dim=-1)\n",
    "    q = F.log_softmax(q_logits, dim=-1)\n",
    "    return torch.sum(torch.exp(p) * (p - q), dim=-1)\n",
    "\n",
    "def l2(x): return torch.norm(x.float(), dim=-1)\n",
    "\n",
    "def token_prob_sum(logits, token_strs: List[str]) -> float:\n",
    "    ids = []\n",
    "    for s in token_strs:\n",
    "        toks = tokenizer.encode(s, add_special_tokens=False)\n",
    "        if len(toks) == 1:\n",
    "            ids.append(toks[0])\n",
    "    if not ids: return 0.0\n",
    "    probs = F.softmax(logits, dim=-1)[..., ids]\n",
    "    return probs.sum(-1).item()\n",
    "\n",
    "# ---------------- Hooking helpers ----------------\n",
    "@dataclass(frozen=True)\n",
    "class LayerSpec:\n",
    "    kind: Literal[\"attn\",\"mlp\"]\n",
    "    idx: int\n",
    "\n",
    "    \n",
    "def get_layer_module(m: nn.Module, spec: LayerSpec) -> nn.Module:\n",
    "    try:\n",
    "        # Check for the multi-modal Gemma 3 structure first. This is more specific.\n",
    "        if hasattr(m, 'model') and hasattr(m.model, 'language_model') and hasattr(m.model.language_model, 'layers'):\n",
    "            layer = m.model.language_model.layers[spec.idx]\n",
    "        # Fall back to the standard text-only transformer structure\n",
    "        elif hasattr(m, 'model') and hasattr(m.model, 'layers'):\n",
    "            layer = m.model.layers[spec.idx]\n",
    "        else:\n",
    "            # If neither structure is found, raise an error.\n",
    "            raise AttributeError(\"Model does not have a recognizable '.model.layers' or '.model.language_model.layers' structure.\")\n",
    "\n",
    "        # Once the correct layer is found, access the specified module\n",
    "        if spec.kind == \"attn\":\n",
    "            return layer.self_attn\n",
    "        elif spec.kind == \"mlp\":\n",
    "            return layer.mlp\n",
    "        else:\n",
    "            raise ValueError(f\"Invalid layer kind '{spec.kind}'. Must be 'attn' or 'mlp'.\")\n",
    "            \n",
    "    except (AttributeError, IndexError) as e:\n",
    "        # This provides a much clearer error message if the structure is wrong\n",
    "        gemma3_path = f\"model.language_model.layers[{spec.idx}]\"\n",
    "        llama_path = f\"model.layers[{spec.idx}]\"\n",
    "        raise AttributeError(\n",
    "            f\"Could not access the specified layer in the model. \"\n",
    "            f\"Tried paths for multi-modal Gemma ('{gemma3_path}') and standard Llama ('{llama_path}'), but failed. \"\n",
    "            f\"Please double-check the model architecture. Original error: {e}\"\n",
    "        )\n",
    "\n",
    "def _as_tensor(output):\n",
    "    # Some HF modules may return tuple; we normalize to a tensor for replacement logic\n",
    "    if isinstance(output, tuple):\n",
    "        return output[0]\n",
    "    return output\n",
    "\n",
    "def _repack_like(original_output, new_tensor):\n",
    "    # Put new_tensor back into the original structure if needed\n",
    "    if isinstance(original_output, tuple):\n",
    "        lst = list(original_output)\n",
    "        lst[0] = new_tensor\n",
    "        return tuple(lst)\n",
    "    return new_tensor\n",
    "\n",
    "class Capture:\n",
    "    \"\"\"Capture module outputs (pre-residual) at all sequence positions.\"\"\"\n",
    "    def __init__(self, model: nn.Module, specs: List[LayerSpec]):\n",
    "        self.handles = []\n",
    "        self.data: Dict[LayerSpec, torch.Tensor] = {}\n",
    "        for s in specs:\n",
    "            mod = get_layer_module(model, s)\n",
    "            h = mod.register_forward_hook(self._make_hook(s))\n",
    "            self.handles.append(h)\n",
    "    def _make_hook(self, spec):\n",
    "        def hook(module, inp, out):\n",
    "            self.data[spec] = _as_tensor(out).detach()\n",
    "        return hook\n",
    "    def remove(self):\n",
    "        for h in self.handles: h.remove()\n",
    "        self.handles = []\n",
    "\n",
    "class Intervention:\n",
    "    \"\"\"Generic intervention hook using a function f(spec, output)->new_output.\"\"\"\n",
    "    def __init__(self, model: nn.Module, specs: List[LayerSpec], fn):\n",
    "        self.handles = []\n",
    "        self.fn = fn\n",
    "        for s in specs:\n",
    "            mod = get_layer_module(model, s)\n",
    "            h = mod.register_forward_hook(self._make_hook(s))\n",
    "            self.handles.append(h)\n",
    "    def _make_hook(self, spec):\n",
    "        def hook(module, inp, out):\n",
    "            out_t = _as_tensor(out)\n",
    "            new_t = self.fn(spec, out_t)\n",
    "            return _repack_like(out, new_t)\n",
    "        return hook\n",
    "    def remove(self):\n",
    "        for h in self.handles: h.remove()\n",
    "        self.handles = []\n",
    "\n",
    "# ---------------- Core experiments ----------------\n",
    "def run_baseline(prompt: str):\n",
    "    with torch.no_grad():\n",
    "        enc = tok(prompt)\n",
    "        out = model(**enc)\n",
    "        return enc, out.logits, out.hidden_states if hasattr(out, \"hidden_states\") else None\n",
    "\n",
    "# This is not called\n",
    "def zero_ablation_curve(prompts: List[str], layer_specs: List[LayerSpec], eval_pos=\"last\"):\n",
    "    \"\"\"Per-layer zero ablation → KL and Hydra stats at eval_pos.\"\"\"\n",
    "    kl_by_layer = {s: [] for s in layer_specs}\n",
    "    hydra_by_layer = {s: [] for s in layer_specs}  # (||Δembed||, KL)\n",
    "\n",
    "    for prompt in prompts:\n",
    "        enc, base_logits = generate_logits(prompt)\n",
    "        input_ids = enc[\"input_ids\"]\n",
    "        pos = pick_eval_index(input_ids, prompt, eval_pos)\n",
    "        base_next = base_logits[:, pos, :]  # next-token distribution\n",
    "\n",
    "        for spec in layer_specs:\n",
    "            # Capture original output to compute Δembed norm\n",
    "            cap = Capture(model, [spec])\n",
    "            _ = model(**enc)  # fill cap.data\n",
    "            cap.remove()\n",
    "            orig = cap.data[spec]  # [B, T, d]\n",
    "            delta_embed_norm = l2(orig[:, pos, :]).item()\n",
    "\n",
    "            # Zero-out hook\n",
    "            def zero_fn(s, out): \n",
    "                return torch.zeros_like(out)\n",
    "\n",
    "            hook = Intervention(model, [spec], zero_fn)\n",
    "            with torch.no_grad():\n",
    "                out = model(**enc)\n",
    "                hook.remove()\n",
    "            logits_abl = out.logits[:, pos, :]\n",
    "\n",
    "            kl = kl_divergence(base_next, logits_abl).item()\n",
    "            kl_by_layer[spec].append(kl)\n",
    "            hydra_by_layer[spec].append((delta_embed_norm, kl))\n",
    "            torch.cuda.empty_cache(); gc.collect()\n",
    "\n",
    "    # average across prompts\n",
    "    kl_avg = {s: float(np.mean(v)) for s, v in kl_by_layer.items()}\n",
    "    hydra_avg = {s: (float(np.mean([a for a,b in v])), float(np.mean([b for a,b in v])))\n",
    "                 for s, v in hydra_by_layer.items()}\n",
    "    return kl_avg, hydra_avg\n",
    "\n",
    "def cross_swap_once(config: DatasetPairConfig, idx, spec: LayerSpec, eval_pos=\"last\"):\n",
    "    \"\"\"Swap the module output at spec between A and B runs (last-token position).\"\"\"\n",
    "    with torch.no_grad():\n",
    "        prompt_a = config.prompts[idx][0]\n",
    "        prompt_b = config.prompts[idx][1]\n",
    "        enc_a = tok(prompt_a); enc_b = tok(prompt_b)\n",
    "\n",
    "        # Capture outputs\n",
    "        cap_a = Capture(model, [spec]); _ = model(**enc_a); cap_a.remove()\n",
    "        cap_b = Capture(model, [spec]); _ = model(**enc_b); cap_b.remove()\n",
    "        A = cap_a.data[spec]; B = cap_b.data[spec]  # [1, T, d]\n",
    "\n",
    "        # Align lengths; use last token only to be safe\n",
    "        def swap_fn_factory(src_vec):\n",
    "            def fn(s, out):\n",
    "                out2 = out.clone()\n",
    "                out2[:, -1, :] = src_vec[:, -1, :].to(out2.dtype).to(out2.device)\n",
    "                return out2\n",
    "            return fn\n",
    "\n",
    "        pos_a = pick_eval_index(enc_a[\"input_ids\"], prompt_a, eval_pos)\n",
    "        pos_b = pick_eval_index(enc_b[\"input_ids\"], prompt_b, eval_pos)\n",
    "\n",
    "        # Baseline logits at pos\n",
    "        base_a = model(**enc_a).logits[:, pos_a, :]\n",
    "        base_b = model(**enc_b).logits[:, pos_b, :]\n",
    "\n",
    "        # A <- B\n",
    "        hook = Intervention(model, [spec], swap_fn_factory(B))\n",
    "        out = model(**enc_a); hook.remove()\n",
    "        swap_a = out.logits[:, pos_a, :]\n",
    "\n",
    "        # B <- A\n",
    "        hook = Intervention(model, [spec], swap_fn_factory(A))\n",
    "        out = model(**enc_b); hook.remove()\n",
    "        swap_b = out.logits[:, pos_b, :]\n",
    "\n",
    "        # Language-bias scores\n",
    "        score_a_before = token_prob_sum(base_a, list(config.a.token_set)) - token_prob_sum(base_a, list(config.b.token_set))\n",
    "        score_a_after  = token_prob_sum(swap_a, list(config.a.token_set)) - token_prob_sum(swap_a, list(config.b.token_set))\n",
    "        score_b_before = token_prob_sum(base_b, list(config.b.token_set)) - token_prob_sum(base_b, list(config.a.token_set))\n",
    "        score_b_after  = token_prob_sum(swap_b, list(config.b.token_set)) - token_prob_sum(swap_b, list(config.a.token_set))\n",
    "        push_b = token_prob_sum(swap_a, list(config.b.token_set)) - token_prob_sum(base_a, list(config.b.token_set))\n",
    "        push_a = token_prob_sum(swap_b, list(config.a.token_set)) - token_prob_sum(base_b, list(config.a.token_set))\n",
    "        kl_a = kl_divergence(base_a, swap_a).item()\n",
    "        kl_b = kl_divergence(base_b, swap_b).item()\n",
    "\n",
    "        return {\n",
    "            \"kl_a\": kl_a, \"kl_b\": kl_b,\n",
    "            # \"score_a_before\": score_a_before, \"score_a_after\": score_a_after,\n",
    "            # \"score_b_before\": score_b_before, \"score_b_after\": score_b_after,\n",
    "            \"push_b_in_a\": push_b, \"push_a_in_b\": push_a\n",
    "        }\n",
    "\n",
    "def compute_concept_means(samples: List[str], specs: List[LayerSpec], max_samples: int = 200):\n",
    "    \"\"\"Mean module output per spec over samples (last token).\"\"\"\n",
    "    means: Dict[LayerSpec, torch.Tensor] = {}\n",
    "    sums: Dict[LayerSpec, torch.Tensor] = {}\n",
    "    count = 0\n",
    "    with torch.no_grad():\n",
    "        for s in samples[:max_samples]:\n",
    "            enc = tok(s)\n",
    "            cap = Capture(model, specs); _ = model(**enc); cap.remove()\n",
    "            for spec in specs:\n",
    "                vec = cap.data[spec][:, -1, :]  # [1, d], last token\n",
    "                if spec not in sums: sums[spec] = vec.clone().to(\"cpu\")\n",
    "                else: sums[spec] += vec.to(\"cpu\")\n",
    "            count += 1\n",
    "    for spec in specs:\n",
    "        means[spec] = (sums[spec] / count)\n",
    "    return means\n",
    "\n",
    "def concept_injection(config, prompt: str, spec: LayerSpec, concept_vec: torch.Tensor, alpha_list: List[float], eval_pos=\"last\"):\n",
    "    \"\"\"Inject ±alpha * concept_vec at layer spec and measure language-bias & KL.\"\"\"\n",
    "    enc, base_logits = generate_logits(prompt)\n",
    "    pos = pick_eval_index(enc[\"input_ids\"], prompt, eval_pos)\n",
    "    base = base_logits[:, pos, :]\n",
    "\n",
    "    results = []\n",
    "    concept = concept_vec.to(DEVICE).to(DTYPE)\n",
    "    def inj_fn_factory(alpha):\n",
    "        def fn(s, out):\n",
    "            out2 = out.clone()\n",
    "            out2[:, -1, :] = out2[:, -1, :] + alpha * concept\n",
    "            return out2\n",
    "        return fn\n",
    "\n",
    "    for alpha in alpha_list:\n",
    "        hook = Intervention(model, [spec], inj_fn_factory(alpha))\n",
    "        out = model(**enc); hook.remove()\n",
    "        logits = out.logits[:, pos, :]\n",
    "\n",
    "        score = token_prob_sum(logits, list((config.a.token_set))) - token_prob_sum(logits, list((config.b.token_set)))\n",
    "        kl = kl_divergence(base, logits).item()\n",
    "        results.append((alpha, score, kl))\n",
    "    return results\n",
    "\n",
    "# ---------------- Plot helpers ----------------\n",
    "def plot_kl_curve(kl_avg: Dict[LayerSpec, float], title=\"KL after zero-ablation by layer\"):\n",
    "    xs_attn, ys_attn = zip(*sorted([(s.idx, v) for s,v in kl_avg.items() if s.kind==\"attn\"]))\n",
    "    xs_mlp,  ys_mlp  = zip(*sorted([(s.idx, v) for s,v in kl_avg.items() if s.kind==\"mlp\"]))\n",
    "    plt.figure()\n",
    "    plt.plot(xs_attn, ys_attn, marker=\"o\", label=\"Attention\")\n",
    "    plt.plot(xs_mlp, ys_mlp, marker=\"o\", label=\"MLP\")\n",
    "    plt.xlabel(\"Layer index\"); plt.ylabel(\"KL(baseline || ablated)\")\n",
    "    plt.title(title); plt.legend(); plt.show()\n",
    "\n",
    "def plot_hydra(hydra_avg: Dict[LayerSpec, Tuple[float,float]], title=\"Hydra: Δembed vs Δunembed (KL)\"):\n",
    "    xs, ys, cs = [], [], []\n",
    "    for s,(demb, kl) in hydra_avg.items():\n",
    "        xs.append(demb); ys.append(kl); cs.append(\"attn\" if s.kind==\"attn\" else \"mlp\")\n",
    "    plt.figure()\n",
    "    for kind in [\"attn\",\"mlp\"]:\n",
    "        X = [x for x,c in zip(xs,cs) if c==kind]\n",
    "        Y = [y for y,c in zip(ys,cs) if c==kind]\n",
    "        plt.scatter(X, Y, label=kind, alpha=0.8)\n",
    "    plt.xlabel(\"‖Δembed‖ at intervention\"); plt.ylabel(\"KL at output\")\n",
    "    plt.title(title); plt.legend(); plt.show()\n",
    "\n",
    "def plot_alpha_curve(results, title=\"Concept-vector injection\"):\n",
    "    alphas = [a for a,_,_ in results]\n",
    "    scores = [s for _,s,_ in results]\n",
    "    kls    = [k for *_,k in results]\n",
    "    plt.figure(); plt.plot(alphas, scores, marker=\"o\"); plt.xlabel(\"alpha\"); plt.ylabel(\"Language-bias score\"); plt.title(title + \" (bias)\"); plt.show()\n",
    "    plt.figure(); plt.plot(alphas, kls, marker=\"o\"); plt.xlabel(\"alpha\"); plt.ylabel(\"KL\"); plt.title(title + \" (KL)\"); plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T16:40:13.091321Z",
     "iopub.status.busy": "2025-09-24T16:40:13.091213Z",
     "iopub.status.idle": "2025-09-24T16:40:13.110699Z",
     "shell.execute_reply": "2025-09-24T16:40:13.110123Z"
    }
   },
   "outputs": [],
   "source": [
    "# ========= INTERPRETABLE METRICS =========\n",
    "import torch\n",
    "import torch.nn.functional as F\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from collections import defaultdict\n",
    "import json, math\n",
    "\n",
    "# Indicator tokens (single-token only; we filter to those)\n",
    "# PY_CANDIDATES  = [\"def\", \"import\", \":\", \"pass\", \"lambda\", \"print\"]\n",
    "# CPP_CANDIDATES = [\";\", \"::\", \"std\", \"using\", \"cout\", \"#\"]\n",
    "\n",
    "def one_token_ids(cands):\n",
    "    og_len = len(cands)\n",
    "    ids, keep = [], []\n",
    "    for s in cands:\n",
    "        t = tokenizer.encode(s, add_special_tokens=False)\n",
    "        if len(t) == 1:\n",
    "            ids.append(t[0]); keep.append(s)\n",
    "    return ids, keep\n",
    "\n",
    "# ids, tokens = one_token_ids(config.a.token_set)\n",
    "# print(ids, tokens)\n",
    "# ids, tokens = one_token_ids(config.b.token_set)\n",
    "# print(ids, tokens)\n",
    "def create_token_ids(tokenizer, token_set):\n",
    "    token_id_list = []\n",
    "    for element in token_set:\n",
    "        id = tokenizer.encode(element)[1]\n",
    "        # print(tokenizer.decode(id), id)\n",
    "        token_id_list.append(id)\n",
    "    return list(set(token_id_list))\n",
    "\n",
    "def prob_mass_for_ids(logits, ids):\n",
    "\n",
    "    probs = F.softmax(logits, dim=-1)[..., ids]\n",
    "    # probab = F.softmax(logits, dim=-1)\n",
    "    return probs.sum(-1).item()\n",
    "\n",
    "def kl_divergence(p_logits, q_logits):\n",
    "    p = F.log_softmax(p_logits, dim=-1)\n",
    "    q = F.log_softmax(q_logits, dim=-1)\n",
    "    return torch.sum(torch.exp(p) * (p - q), dim=-1)\n",
    "\n",
    "def next_token_logits_at_first_code(model_dict, prompt: str):\n",
    "    tokenizer = model_dict['tokenizer']\n",
    "    model = model_dict['model']\n",
    "    enc = tokenizer(prompt, return_tensors=\"pt\").to(DEVICE)\n",
    "    pos = pick_eval_index(tokenizer, enc[\"input_ids\"], prompt, mode=\"last\")\n",
    "    with torch.no_grad():\n",
    "        out = model(**enc)\n",
    "    return out.logits[:, pos, :].squeeze(0)  # [V]\n",
    "\n",
    "def cross_swap_verbose(model_dict, config: DatasetPairConfig, prompt_a: str, prompt_b: str, spec: LayerSpec, token_ids_a, token_ids_b):\n",
    "    # Baselines\n",
    "    tokenizer = model_dict['tokenizer']\n",
    "    model = model_dict['model']\n",
    "    base_a = next_token_logits_at_first_code(model_dict, prompt_a)\n",
    "    base_b  = next_token_logits_at_first_code(model_dict, prompt_b)\n",
    "    \n",
    "    # Capture layer outputs on last prompt position\n",
    "    enc_a = tokenizer(prompt_a, return_tensors=\"pt\").to(DEVICE)\n",
    "    enc_b  = tokenizer(prompt_b,  return_tensors=\"pt\").to(DEVICE)\n",
    "    capA = Capture(model, [spec]); _ = model(**enc_a); capA.remove()\n",
    "    capB = Capture(model, [spec]); _ = model(**enc_b);  capB.remove()\n",
    "    A = capA.data[spec][:, -1, :]  # C++ layer output at last prompt token\n",
    "    B = capB.data[spec][:, -1, :]  # Python layer output\n",
    "\n",
    "    def swap_fn(vec):\n",
    "        def fn(s, out):\n",
    "            out2 = out.clone()\n",
    "            out2[:, -1, :] = vec.to(out2)\n",
    "            return out2\n",
    "        return fn\n",
    "\n",
    "    # C++ side: insert Python vec\n",
    "    hook = Intervention(model, [spec], swap_fn(B))\n",
    "    out_a = model(**enc_a); hook.remove()\n",
    "    pos_a = pick_eval_index(tokenizer, enc_a[\"input_ids\"], prompt_a, \"last\")\n",
    "    swap_a = out_a.logits[:, pos_a, :].squeeze(0)\n",
    "\n",
    "    # Python side: insert C++ vec\n",
    "    hook = Intervention(model, [spec], swap_fn(A))\n",
    "    out_b = model(**enc_b); hook.remove()\n",
    "    pos_b = pick_eval_index(tokenizer, enc_b[\"input_ids\"], prompt_b, \"last\")\n",
    "    swap_b = out_b.logits[:, pos_b, :].squeeze(0)\n",
    "\n",
    "    def summarize(side, base, new):\n",
    "        # print(token_ids_b)\n",
    "        kl = kl_divergence(base.unsqueeze(0), new.unsqueeze(0)).item()\n",
    "        b_before  = prob_mass_for_ids(base, token_ids_b)\n",
    "        a_before = prob_mass_for_ids(base, token_ids_a)\n",
    "        b_after   = prob_mass_for_ids(new, token_ids_b)\n",
    "        a_after  = prob_mass_for_ids(new,  token_ids_a)\n",
    "        bias_before = b_before - a_before\n",
    "        bias_after  = b_after  - a_after\n",
    "        return dict(\n",
    "            side=side, KL=kl,\n",
    "            b_before=b_before, a_before=a_before,\n",
    "            b_after=b_after,   a_after=a_after,\n",
    "            delta_bias=bias_after - bias_before,\n",
    "        )\n",
    "\n",
    "    output = {\n",
    "        \"spec\": (spec.kind, spec.idx),\n",
    "        config.a.name: summarize(config.a.name.upper(), base_a, swap_a),\n",
    "        config.b.name: summarize(config.b.name.upper(),  base_b,  swap_b),\n",
    "    }\n",
    "    # print(output)\n",
    "    return output\n",
    "    \n",
    "\n",
    "\n",
    "# ========= BATCH & AVERAGING =========\n",
    "def run_cross_swap_batch(model_dict, config: DatasetPairConfig, layer_specs):\n",
    "    \"\"\"\n",
    "    paired_prompts: list of (cpp_prompt, py_prompt)\n",
    "    returns dict keyed by (kind, idx) with averages across pairs\n",
    "    \"\"\"\n",
    "    tokenizer = model_dict[\"tokenizer\"]\n",
    "    token_ids_a = create_token_ids(tokenizer, config.a.token_set)\n",
    "    token_ids_b = create_token_ids(tokenizer, config.b.token_set)\n",
    "    paired_prompts = config.prompts\n",
    "    print(len(paired_prompts))\n",
    "    agg = defaultdict(lambda: {config.a.name: defaultdict(list), config.b.name: defaultdict(list)})\n",
    "    for (a_p, b_p) in paired_prompts:\n",
    "        for spec in layer_specs:\n",
    "            res = cross_swap_verbose(model_dict, config, a_p, b_p, spec, token_ids_a, token_ids_b)\n",
    "            kind, idx = res[\"spec\"]\n",
    "            k = f\"{kind}-{idx}\"\n",
    "            for side in [config.a.name,config.b.name]:\n",
    "                for key, val in res[side].items():\n",
    "                    if key in [\"side\"]: continue\n",
    "                    agg[k][side][key].append(val)\n",
    "\n",
    "    # average\n",
    "    # out = {}\n",
    "    # for k, sides in agg.items():\n",
    "    #     out[k] = {}\n",
    "    #     for side, metrics in sides.items():\n",
    "    #         out[k][side] = {m: float(np.mean(vals)) for m, vals in metrics.items()}\n",
    "    # return out\n",
    "    \n",
    "    # compute mean and std\n",
    "    out = {}\n",
    "    for k, sides in agg.items():\n",
    "        out[k] = {}\n",
    "        for side, metrics in sides.items():\n",
    "            out[k][side] = {\n",
    "                m: {\n",
    "                    \"mean\": float(np.mean(vals)),\n",
    "                    \"std\": float(np.std(vals, ddof=1)) if len(vals) > 1 else 0.0\n",
    "                }\n",
    "                for m, vals in metrics.items()\n",
    "            }\n",
    "    return out\n",
    "\n",
    "def run_cross_swap_average(config, layer_specs):\n",
    "    \"\"\"\n",
    "    Runs cross_swap_verbose over all prompt pairs in config.prompts\n",
    "    and averages KL divergence and shift metrics for each layer spec.\n",
    "\n",
    "    Returns dict keyed by (kind, idx), with averages for both sides.\n",
    "    \"\"\"\n",
    "    paired_prompts = config.prompts\n",
    "\n",
    "    # aggregate storage\n",
    "    agg = defaultdict(lambda: {config.a.name: defaultdict(list),\n",
    "                               config.b.name: defaultdict(list)})\n",
    "\n",
    "    # run cross swap for all prompt pairs and layer specs\n",
    "    for (a_p, b_p) in paired_prompts:\n",
    "        for spec in layer_specs:\n",
    "            res = cross_swap_verbose(config, a_p, b_p, spec)\n",
    "            k = res[\"spec\"]\n",
    "            for side in [config.a.name, config.b.name]:\n",
    "                for key, val in res[side].items():\n",
    "                    if key == \"side\": \n",
    "                        continue\n",
    "                    agg[k][side][key].append(val)\n",
    "\n",
    "    # compute averages\n",
    "    out = {}\n",
    "    for k, sides in agg.items():\n",
    "        out[k] = {}\n",
    "        for side, metrics in sides.items():\n",
    "            out[k][side] = {m: float(np.mean(vals)) for m, vals in metrics.items()}\n",
    "    return out\n",
    "\n",
    "\n",
    "def plot_cross_swap_kl(config:DatasetPairConfig, results, title=\"Cross-swap KL by layer (C++ & Python sides)\", save=\"crossswap_kl.png\"):\n",
    "    a = config.a.name\n",
    "    b = config.b.name\n",
    "    labels = []\n",
    "    kl_a, kl_b = [], []\n",
    "    std_a, std_b = [], []\n",
    "\n",
    "    # collect means and stds\n",
    "    # for (kind, idx), sides in sorted(results.items(), key=lambda x: (x[0][0], x[0][1])):\n",
    "    for (kind, idx), sides in results.items():\n",
    "        labels.append(f\"{kind.upper()}-{idx}\")\n",
    "        kl_a.append(sides[a][\"KL\"][\"mean\"])\n",
    "        kl_b.append(sides[b][\"KL\"][\"mean\"])\n",
    "        std_a.append(sides[a][\"KL\"][\"std\"])\n",
    "        std_b.append(sides[b][\"KL\"][\"std\"])\n",
    "\n",
    "    x = np.arange(len(labels))\n",
    "    w = 0.38\n",
    "    plt.figure(figsize=(10, 4))\n",
    "\n",
    "    # bars with error bars (std)\n",
    "    plt.bar(x - w/2, kl_a, width=w, label=\"KL on \" + a.upper() + \" prompt\", yerr=std_a, capsize=5)\n",
    "    plt.bar(x + w/2, kl_b,  width=w, label=\"KL on \" + b.upper() + \" prompt\", yerr=std_b, capsize=5)\n",
    "\n",
    "    plt.xticks(x, labels, rotation=45, ha=\"right\")\n",
    "    plt.ylabel(\"KL(baseline || swapped)\")\n",
    "    plt.title(title)\n",
    "    plt.legend()\n",
    "    plt.tight_layout()\n",
    "    directory = os.path.dirname(save)\n",
    "    if directory:\n",
    "        os.makedirs(directory, exist_ok=True)\n",
    "    plt.savefig(save, dpi=220, bbox_inches=\"tight\")\n",
    "    plt.show()\n",
    "    \n",
    "    print(f\"Saved to {save}\")\n",
    "\n",
    "def plot_cross_swap_bias(config: DatasetPairConfig, results, title=\"Language-bias shift Δ (Py mass − C++ mass)\", save=\"crossswap_bias.png\"):\n",
    "    a = config.a.name\n",
    "    b = config.b.name\n",
    "    labels = []\n",
    "    db_a, db_b = [], []\n",
    "    std_a, std_b = [], []\n",
    "\n",
    "    # collect means and stds\n",
    "    #for (kind, idx), sides in sorted(results.items(), key=lambda x:(x[0][0], x[0][1])):\n",
    "    for (kind, idx), sides in results.items():\n",
    "        labels.append(f\"{kind.upper()}-{idx}\")\n",
    "        db_a.append(sides[a][\"delta_bias\"][\"mean\"])\n",
    "        db_b.append(sides[b][\"delta_bias\"][\"mean\"])\n",
    "        std_a.append(sides[a][\"delta_bias\"][\"std\"])\n",
    "        std_b.append(sides[b][\"delta_bias\"][\"std\"])\n",
    "\n",
    "    x = np.arange(len(labels)); w = 0.38\n",
    "    plt.figure(figsize=(10,4))\n",
    "\n",
    "    # bars with error bars (std)\n",
    "    plt.bar(x - w/2, db_a, width=w, label=\"Δ bias on \"+ a.upper() + \" prompt\", yerr=std_a, capsize=5)\n",
    "    plt.bar(x + w/2, db_b,  width=w, label=\"Δ bias on \" + b.upper() + \" prompt\", yerr=std_b, capsize=5)\n",
    "\n",
    "    plt.axhline(0, linestyle=\"--\", linewidth=1)\n",
    "    plt.xticks(x, labels, rotation=45, ha=\"right\")\n",
    "    plt.ylabel(f\"After − Before  (P[{b} tokens] − P[{a} tokens])\")\n",
    "    plt.title(title)\n",
    "    plt.legend()\n",
    "    plt.tight_layout()\n",
    "    plt.savefig(save, dpi=220, bbox_inches=\"tight\")\n",
    "    plt.show()\n",
    "    # print(f\"Saved {save}\")\n",
    "\n",
    "\n",
    "# ========= HYDRA (ZERO-ABLATION) =========\n",
    "def zero_ablation_curve_avg(paired_prompts, layer_specs):\n",
    "    kl_by_layer = defaultdict(list)\n",
    "    hydra_by_layer = defaultdict(list)  # (||Δembed||, KL)\n",
    "    for (cpp_p, py_p) in paired_prompts:\n",
    "        for prompt in [cpp_p, py_p]:\n",
    "            enc = tokenizer(prompt, return_tensors=\"pt\").to(DEVICE)\n",
    "            pos = pick_eval_index(enc[\"input_ids\"], prompt, \"first_code\")\n",
    "            with torch.no_grad():\n",
    "                base = model(**enc).logits[:, pos, :]\n",
    "            for spec in layer_specs:\n",
    "                # magnitude of the thing we're zeroing (||Δembed||)\n",
    "                cap = Capture(model, [spec]); _ = model(**enc); cap.remove()\n",
    "                orig = cap.data[spec]  # [1, T, d]\n",
    "                mag = torch.norm(orig[:, pos, :].float(), dim=-1).item()\n",
    "\n",
    "                def zero_fn(s, out): return torch.zeros_like(out)\n",
    "                hook = Intervention(model, [spec], zero_fn)\n",
    "                with torch.no_grad():\n",
    "                    out = model(**enc); hook.remove()\n",
    "                abl = out.logits[:, pos, :]\n",
    "\n",
    "                KL = kl_divergence(base, abl).item()\n",
    "                kl_by_layer[(spec.kind, spec.idx)].append(KL)\n",
    "                hydra_by_layer[(spec.kind, spec.idx)].append((mag, KL))\n",
    "                torch.cuda.empty_cache()\n",
    "\n",
    "    # average\n",
    "    kl_avg = {k: float(np.mean(v)) for k, v in kl_by_layer.items()}\n",
    "    hydra_avg = {k: (float(np.mean([a for a,b in v])), float(np.mean([b for a,b in v])))\n",
    "                 for k, v in hydra_by_layer.items()}\n",
    "    return kl_avg, hydra_avg\n",
    "\n",
    "def plot_hydra(hydra_avg, annotate=set(), title=\"Hydra: sensitivity by layer\", save=\"hydra.png\"):\n",
    "    xs_attn, ys_attn, lab_attn = [], [], []\n",
    "    xs_mlp,  ys_mlp,  lab_mlp  = [], [], []\n",
    "    for (kind, idx), (demb, KL) in hydra_avg.items():\n",
    "        if kind==\"attn\":\n",
    "            xs_attn.append(demb); ys_attn.append(KL); lab_attn.append(idx)\n",
    "        else:\n",
    "            xs_mlp.append(demb);  ys_mlp.append(KL); lab_mlp.append(idx)\n",
    "\n",
    "    plt.figure(figsize=(6,5))\n",
    "    plt.scatter(xs_attn, ys_attn, label=\"Attention\", alpha=0.85)\n",
    "    plt.scatter(xs_mlp,  ys_mlp,  label=\"MLP\", alpha=0.85)\n",
    "\n",
    "    # reference line Y = c X\n",
    "    all_x = xs_attn + xs_mlp; all_y = ys_attn + ys_mlp\n",
    "    c = (sum(all_y)+1e-9)/(sum(all_x)+1e-9)\n",
    "    xline = np.linspace(0, max(all_x+[1.0]), 100)\n",
    "    plt.plot(xline, c*xline, linestyle=\"--\", label=f\"reference (Y≈{c:.3f}X)\")\n",
    "\n",
    "    # annotate selected layers\n",
    "    for (kind, idx) in annotate:\n",
    "        if kind==\"attn\":\n",
    "            i = lab_attn.index(idx); plt.text(xs_attn[i], ys_attn[i], f\"A{idx}\", fontsize=9)\n",
    "        else:\n",
    "            i = lab_mlp.index(idx);  plt.text(xs_mlp[i],  ys_mlp[i],  f\"M{idx}\", fontsize=9)\n",
    "\n",
    "    plt.xlabel(\"‖Δembed‖ at layer when zeroed (magnitude of cut)\")\n",
    "    plt.ylabel(\"KL change at output (baseline || ablated)\")\n",
    "    plt.title(title); plt.legend()\n",
    "    plt.tight_layout()\n",
    "    plt.savefig(save, dpi=220, bbox_inches=\"tight\"); plt.show()\n",
    "    print(f\"Saved {save}\")\n",
    "    \n",
    "    \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T16:40:13.112503Z",
     "iopub.status.busy": "2025-09-24T16:40:13.112401Z",
     "iopub.status.idle": "2025-09-24T16:40:13.334083Z",
     "shell.execute_reply": "2025-09-24T16:40:13.332998Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Ranking acc to attn:  [17, 16, 0, 2, 19, 21, 23, 22, 3, 24, 7, 26, 25, 15, 18, 27, 1, 20, 4, 13, 10, 12, 11, 5, 6, 8, 14, 9]\n",
      "Ranking acc to mlp:  [0, 19, 17, 20, 18, 21, 27, 22, 23, 16, 3, 24, 26, 25, 2, 1, 4, 15, 5, 14, 13, 7, 12, 11, 6, 8, 10, 9]\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA04AAAHWCAYAAABACtmGAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjUsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvWftoOwAAAAlwSFlzAAAPYQAAD2EBqD+naQAAx1pJREFUeJzs3Xd4VGXax/HvTHoPgYRQQu+9CaIoRRAUXQsoooigi67Cri7rrrL6grgqujbsHVgVFcXeUKQICIpKU+m9BRII6aTOef84zCQhbSaZyUyS3+e6cs1k5syZO5OTmdznuZ/7sRiGYSAiIiIiIiLlsno7ABEREREREV+nxElERERERKQSSpxEREREREQqocRJRERERESkEkqcREREREREKqHESUREREREpBJKnERERERERCqhxElERERERKQSSpxEREREREQqocRJpAr279+PxWJhwYIFLj2uVatWXHbZZZ4JSkqYNGkS4eHhTm1rsVh44IEHHN8vWLAAi8XC/v37HbcNGTKEIUOGuDdIqbfuuOMORowY4e0wROqs6667jmuvvdbbYUgdo8RJpAz2f5zL+rr33nu9HV615OXl8cwzz9C7d28iIyOJjo6ma9eu3HrrrWzfvt3b4dUaR48e5YEHHmDTpk0ee45//etfWCwWxo0b57Hn8Lb6eDJh3759vP766/z73/8udV96ejqzZ8+mZ8+ehIeHExISQrdu3bjnnns4evSoY7tJkyaVeF+KjIykZ8+ePPnkk+Tm5jq2e+CBB0psFxoaSpcuXbj//vtJT093Kt6zn6u8r0mTJjkeYxgGb731FhdeeCHR0dGEhobSvXt3HnzwQbKysko9x5AhQ0rsKyYmhnPOOYd58+Zhs9lceHXdr7LXcN++fYSGhjJ+/PgyH79o0SIsFgsvvPCCU6+jxWIBij6HfvnllzL3O2TIELp161bq9vz8fJ599lnOOeccIiIiCA8P55xzzuHZZ58lPz+/1PatWrXCYrHw17/+tdR9K1euxGKxsHjxYqdeK186Vu655x4+/PBDNm/e7FTsIs7w93YAIr7swQcfpHXr1iVu69atGy1btuT06dMEBAR4KbKqGzNmDF9//TXjx49nypQp5Ofns337dr744gvOO+88OnXq5O0Qa9zp06fx96/47fDbb78t8f3Ro0eZPXs2rVq1olevXm6PyTAM3n33XVq1asXnn39ORkYGERERbn8eqXnPPPMMrVu3ZujQoSVu37t3L8OHD+fgwYNcc8013HrrrQQGBrJlyxbeeOMNPv74Y3bu3OnYPigoiNdffx2A1NRUPvzwQ+6++25+/vln3nvvvRL7fumllwgPDyczM5Nvv/2Whx9+mOXLl/PDDz84/lEvz2233cbw4cMd3+/bt4+ZM2dy6623csEFFzhub9u2LQCFhYVcf/31vP/++1xwwQU88MADhIaGsnr1ambPns0HH3zAd999R+PGjUs8T/PmzZkzZw4AycnJvPnmm9xyyy3s3LmTRx991NmX12Mqeg1nzZrFvffey+TJk7n44osdj0lPT+fvf/87AwYMYOzYsURFRZXY54wZMwgPD+e+++5zS4xZWVmMHj2a77//nssuu4xJkyZhtVpZsmQJd955Jx999BFffvklYWFhpR772muvMWPGDJo2bVrl5/elY6V3797069ePJ598kjfffLPKP5NICYaIlDJ//nwDMH7++We37rdly5bG6NGj3brPs+Xn5xu5ubll3rd+/XoDMB5++OFS9xUUFBgnTpzwaGzVkZmZ6dL2N910kxEWFlal57L//vft21fuNj///LMBGPPnz6/Sc1Rm+fLlBmAsX77cCAgIMBYsWOC2fbv6WnpSTfxNuFN1X7u8vDyjUaNGxv3331/i9vz8fKNnz55GaGiosXr16lKPS0tLM/797387vi/r+C4sLDT69etnAMaRI0cMwzCMWbNmGYCRnJxcYturr77aAIy1a9e6/DNUduw/8sgjBmDcfffdpe777LPPDKvVaowaNarE7YMHDza6du1a4rasrCyjefPmRlhYmJGXl+dynO7izGuYn59vdO/e3Wjbtq2RnZ3t2GbatGmGv7+/sXnz5jL33bVrV2Pw4MFl3lfZ51BZr9mtt95qAMZzzz1Xavvnn3/eAIy//OUvJW5v2bKl0bVrV8Pf39/461//WuK+FStWGIDxwQcflBlDZbx9rDzxxBNGWFiYkZGRUaX4Rc6mUj2RKihrjtOxY8eYPHkyzZs3JygoiCZNmnDFFVeUmCdjt2bNGvr3709wcDBt2rQp82xYamoqd911FwkJCQQFBdGuXTsee+yxEqUI9jieeOIJ5s6dS9u2bQkKCmLr1q1lxr1nzx4Azj///FL3+fn50bBhwxK3HTlyhJtvvpnGjRsT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Bg4cWOZjzj//fHbv3l2iFnHnzp00adKkzKRJREREnGQYsOxMaXufG6FhW888j70dubrqiUgt49WUdfr06bz22mv873//Y9u2bdx+++1kZWU5uuxNnDixRPOI22+/nZSUFO6880527tzJl19+ySOPPMLUqVO99SOIiIjUDbu/g4PrwC8IBt/juecp3lVPi4qKSC3i1TlO48aNIzk5mZkzZ3Ls2DF69erFkiVLHA0jDh48WGL4LCEhgW+++Ya///3v9OjRg2bNmnHnnXdyzz0efIMXERGp62w2WPageb3/FIhs6rnnso84FZyG3AwI9v58YxERZ3i9OcS0adOYNm1amfetXLmy1G0DBw7kxx9/9HBUIiIi9cjWT+DYFgiMgEHTK928WgLDICAM8rMgK1mJk4jUGl5PnERERKQGpR6C7JNF39sKYen/mde7j4X8bKChZ2MIj4VTWZCZ5Lm5VCIibqbESUREpL5IPQTP94WC3LLv/3U+bH4Hpv0K0QmeiyMsDk7tV4MIEalV1M9QRESkvsg+WX7SZFeQW3JEyhPs85wylTiJSO2hxElERERqlqMlebJ34xARcYESJxEREalZYRpxEpHaR4mTiIiI1KzwM2s5acRJRGoRJU4iIiJSszTiJCK1kBInERERqVmOOU5KnESk9lDiJCIiIjUr7EypXqZK9USk9lDiJCIiUl+ENgT/oIq38Q8yt/Mk+4hTfhbkZXn2uURE3EQL4IqIiNQX0Qnm4rbZJ2HZg7BnGZx7B/QYV7RNaEPPLn4LEBgO/iFQcNqc5xTT2rPPJyLiBkqcRERE6pPoBPMr/7T5ffN+0LRXzcZgsZid9VIPmp31lDiJSC2gUj0REZH6KP2IeRnZzDvP7+isd9w7zy8i4iIlTiIiIvWNYUBGonk9sql3YghXS3IRqV2UOImIiNQ32SehMA+wQHi8d2II0yK4IlK7KHESERGpb+xlemGx4B/onRg04iQitYwSJxERkfom/ah56a0yPSia46RFcEWkllDiJCIiUt94uzEEFBtxUqmeiNQOSpxERETqG18YcQrXiJOI1C5KnEREROobX0icwjTiJCK1ixInERGR+saROHmzVO9MV728jKLFeEVEfJgSJxERkfrGF0acgiLBL8i8rs56IlILKHESERGpTwzDNxIni6XYPCeV64mI71PiJCIiUp/kpEF+lnk9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",
      "text/plain": [
       "<Figure size 1000x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Ranking acc to attn:  [5, 7, 6, 2, 8, 0, 1, 23, 21, 11, 10, 27, 3, 26, 9, 12, 22, 25, 13, 24, 4, 18, 17, 15, 16, 14, 19, 20]\n",
      "Ranking acc to mlp:  [12, 27, 9, 11, 13, 8, 15, 14, 7, 10, 16, 6, 17, 18, 0, 5, 19, 3, 26, 20, 4, 21, 25, 2, 23, 22, 24, 1]\n"
     ]
    },
    {
     "data": {
      "image/png": "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GAwGTp8+nSvRPHHiBEChA/jNUdQV3KFDh/Lggw+yZ88eU8ECY/GPwixatIiGDRsyefLkPI999dVXLF68mClTphAQEICXl1exv6QaC4UcP34815X3jIwMoqOj8/zdGzVqRKNGjXjjjTfYvn077du358svvzSVV9br9dx7773ce++9zJgxg3fffZfXX3+djRs3lug8tvRvPnToUD766CNWrFjBqlWrCAgIMBUJAEzz2Xh5eZX4/6s4/+/16tVj0aJFJCYmmlrsClOjRg18fX25fPkyoF40qVu3LsuXL2fWrFml8uX7djVr1mTIkCF89dVXtG7dOs/j999/P3PmzGHHjh35zgdlbQMGDGDKlCn88ssvBAUFkZSUxMCBA/NsFxISwjPPPMMzzzxDTEwMzZs355133rEocXrooYd46qmn2LlzJ0uWLClwO+P8TlOnTqV+/fq5Hrt+/TqjR4/mt99+K5US7NHR0ej1+jwX24Qoq2SMkxDlQGpqap4S0zVr1sTT05P09HSL9/foo4+yY8eOfPvCJyQkkJWVVaw4o6KiOHfuXL773LFjB76+vgQEBODg4ED//v355Zdf8v1inl+p7W+//TZXF52lS5dy+fJl0xcTY6vD7S1riqIwa9Yss+Mvzj5mz56da9vZs2fj5OTEvffea/Zx82Ocy6egua969uyJv78/06dPZ/PmzWZ9STp//jxbtmzh0Ucf5eGHH85zGz58OCdPnmTXrl3o9Xr69u3LihUr2Lt3b559FdQdzKhr1644OzvzySef5Np23rx5JCYmmroSJSUl5TnfGjVqhF6vN53b8fHxefZvbM0pzvl/O0v/5sb5cebOncsvv/zCwIEDc7U+tGjRgpo1a/Lhhx+SnJyc5/n5ndt3Ksn/e9u2bVEUhX/++SfX+l27dpmqHd5u9+7dXLt2LVeXyilTpnDt2jVGjhyZ73vBmjVrTKW4beGNN94gMzOT999/P89jL7/8Mh4eHowcOZKrV6/mefzUqVMW/c8XpX79+jRq1IglS5awZMkSQkJCuPvuu02PZ2dn5+nCGxgYSGhoqMXnZqVKlfjiiy9466236NOnT4HbGbvpvfTSS3n+h0eNGmVqQSwN//zzDw0aNDArSReiLJAWJyHKgRMnTnDvvffy6KOPEhkZiaOjI7/++itXr17N9+pnUV566SV+//137r//flOp8pSU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nTt3Jioqip07d/Kb3/yGffv28fHHHxsYbduhxEnEQBMnTqz7vn///iQkJNC5c2c++OAD7rnnHgMjExFncPbUzH79+tG/f3/i4+NZt24dY8aMMTAysZeHHnqIXbt2ab1rG9dYO5g1a1bd9/369SMyMpIxY8aQlpZGfHy8o8NsczRVzwAhISG4ubmdUw3nxIkTREREGBSVOIOgoCC6d+/OgQMHjA5FDFJ7DdD1QRoSFxdHSEiIrhEu6uGHH+azzz7j66+/pmPHjnX3R0REUFlZSUFBQb3jdV1wTY21g4YkJCQA6JrgIEqcDODp6cngwYNZs2ZN3X0Wi4U1a9aQmJhoYGRitJKSEtLS0oiMjDQ6FDFIbGwsERER9a4PRUVFbN26VdcH4ejRo+Tl5eka4WKsVisPP/wwn3zyCWvXriU2Nrbe44MHD8bDw6PedWHfvn1kZGTouuBCmmoHDaktLqVrgmNoqp5B5syZw4wZMxgyZAjDhg1j4cKFlJaWMnPmTKNDEwd67LHHmDRpEp07d+b48ePMnTsXNzc3fv7znxsdmthRSUlJvd7B9PR0UlJSCA4OplOnTvzqV7/iL3/5C926dSM2NpY//vGPREVF1au2Jq7hfG0hODiYefPmcfPNNxMREUFaWhpPPPEEXbt2Zfz48QZGLS3toYce4t133+XTTz/F39+/bt1SYGAgPj4+BAYGcs899zBnzhyCg4MJCAjgF7/4BYmJiaqo50KaagdpaWm8++67XHvttXTo0IGdO3fy6KOPMnLkSPr3729w9G2EVQzz0ksvWTt16mT19PS0Dhs2zLplyxajQxIHmzp1qjUyMtLq6elpjY6Otk6dOtV64MABo8MSO/v666+twDm3GTNmWK1Wq9VisVj/+Mc/WsPDw61eXl7WMWPGWPft22ds0GIX52sLZWVl1nHjxllDQ0OtHh4e1s6dO1vvu+8+a1ZWltFhSwtrqA0A1jfffLPumFOnTlkffPBBa/v27a2+vr7WyZMnWzMzM40LWlpcU+0gIyPDOnLkSGtwcLDVy8vL2rVrV+vjjz9uLSwsNDbwNkT7OImIiIiIiDRBa5xERERERESaoMRJRERERESkCUqcREREREREmqDESUREREREpAlKnERERERERJqgxElERERERKQJSpxERERERESaoMRJRERERESkCUqcREREREREmqDESUREWp277rqLm266yegwRESkDVHiJCIicokqKyuNDkFEROxMiZOIiLiUBQsW0K9fP9q1a0dMTAwPPvggJSUlAJSWlhIQEMBHH31U75zly5fTrl07iouLAThy5Ai33norQUFBBAcHc+ONN3Lo0KG642tHvP76178SFRVFjx49HPb+RETEGEqcRETEpZjNZl588UV+/PFH3nrrLdauXcsTTzwBQLt27bjtttt48803653z5ptvcsstt+Dv709VVRXjx4/H39+fjRs38s033+Dn58eECRPqjSytWbOGffv2sWrVKj777DOHvkcREXE8k9VqtRodhIiIyIW46667KCgoYPny5U0e+9FHH/HAAw+Qm5sLQFJSEpdffjlHjhwhMjKS7OxsoqOjWb16NVdddRVLly7lL3/5C3v27MFkMgG2qXhBQUEsX76ccePGcdddd7Fy5UoyMjLw9PS051sVEREnoREnERFxKatXr2bMmDFER0fj7+/PHXfcQV5eHmVlZQAMGzaMPn368NZbbwGwdOlSOnfuzMiRIwHYsWMHBw4cwN/fHz8/P/z8/AgODqa8vJy0tLS61+nXr5+SJhGRNkSJk4iIuIxDhw5x/fXX079/f/7zn/+wfft2Xn75ZaB+AYd7772XJUuWALZpejNnzqwbXSopKWHw4MGkpKTUu6WmpnL77bfXPUe7du0c98ZERMRw7kYHICIi0lK2b9+OxWLh73//O2azrW/wgw8+OOe46dOn88QTT/Diiy+ye/duZsyYUffYoEGDWLZsGWFhYQQEBDgsdhERcW4acRIRkVapsLDwnFGhkJAQqqqqeOmllzh48CBvv/02r7766jnntm/fnilTpvD4448zbtw4OnbsWPfYtGnTCAkJ4cYbb2Tjxo2kp6ezbt06HnnkEY4ePerItygiIk5EiZOIiLRK69at47LLLqt3e/vtt1mwYAHPPPMMffv25Z133mH+/PkNnn/PPfdQWVnJ3XffXe9+X19fNmzYQKdOnZgyZQq9evXinnvuoby8XCNQIiJtmKrqiYhIm/T222/z6KOPcvz4cRV5EBGRJmmNk4iItCllZWVkZmby9NNPc//99ytpEhGRZtFUPRERaVOeffZZevbsSUREBE8++aTR4YiISCuhqXoiIiIiIiJN0IiTiIiIiIhIE5Q4iYiIiIiINEGJk4iIiIiISBOUOImIiIiIiDRBiZOIiIiIiEgTlDiJiIiIiIg0QYmTiIiIiIhIE5Q4iYiIiIiINOH/A58utIG3PxwYAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 1000x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Ranking acc to attn:  [0, 27, 2, 1, 17, 5, 4, 15, 25, 7, 10, 20, 16, 9, 6, 12, 13, 3, 11, 23, 26, 8, 24, 14, 22, 19, 21, 18]\n",
      "Ranking acc to mlp:  [27, 26, 16, 17, 18, 15, 19, 25, 20, 14, 12, 21, 13, 9, 10, 0, 22, 23, 24, 7, 11, 4, 8, 3, 6, 5, 2, 1]\n"
     ]
    },
    {
     "data": {
      "image/png": "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2hx3au2cLJgxwWz3ewhSetnXPhGpEbTGSURERIJXTpaZUtagBRw9COu/AstlgqZjuZDY2QROIiLVpMBJREREglNZSQ4WPGO+3PZnQP4eJTkQkWrTVD0REREJTkpyICJ+pMBJRERERETEAwVOIiIiIqGkTkMIjyp/n/Aos5+InKI1TiIiIiKhpH4KjF1Z/hTGOg21LkzkNAqcREREREJN/RQFRiKVpKl6IiIiIiIiHihwEhERERER8UCBk4iIiAQnJTkQET/SGicREREJTkpyICJ+pMBJREREgpeSHIiIn2iqnoiIiIiIiAcKnERERERERDxQ4CQiIiIiIuKBAicREREREREPFDiJiIiIiIh4oMBJRERERETEAwVOIiIiIiIiHihwEhERERER8UCBk4iIiIiIiAcKnERERERERDwIt7sB/mZZFgB5eXk2t8RwuVzk5+dTq1YtnE7FsaFK/UBA/UBKqC8IqB9ICfUF33HHBO4YoTwhFzjl5+cDkJKSYnNLREREREQkEOTn51OvXr1y93FYFQmvahCXy8WuXbuIiYnB4XDY3Rzy8vJISUkhKyuL2NhYu5sjNlE/EFA/kBLqCwLqB1JCfcF3LMsiPz+fxo0bexzNC7kRJ6fTSdOmTe1uxhliY2P1iyDqBwKoH0gJ9QUB9QMpob7gG55Gmtw0SVJERERERMQDBU4iIiIiIiIeKHCyWVRUFI899hhRUVF2N0VspH4goH4gJdQXBNQPpIT6QmAIueQQIiIiIiIilaURJxEREREREQ8UOImIiIiIiHigwElERERERMQDBU4iIiIiIiIeKHCy0eTJk2nRogW1atWid+/eLF++3O4miZ89/vjjOByOUl/t27e3u1niYwsWLOCKK66gcePGOBwOpk+fXurnlmXx6KOPkpycTO3atRk0aBAbN260p7HiU576wqhRo864RgwdOtSexorPPPXUU/Ts2ZOYmBgSEhIYPnw4GRkZpfYpLCzk3nvvpWHDhtStW5err76a7Oxsm1osvlCRfjBgwIAzrgljxoyxqcWhR4GTTT744AMmTJjAY489xo8//kjXrl0ZMmQIe/futbtp4mcdO3Zk9+7dp74WLVpkd5PExw4fPkzXrl2ZPHlymT9/9tlnefnll3n99df5/vvviY6OZsiQIRQWFvq5peJrnvoCwNChQ0tdI95//30/tlD8Yf78+dx7770sW7aMWbNmcfz4cQYPHszhw4dP7XP//ffzxRdf8L///Y/58+eza9cuRowYYWOrxdsq0g8A7rjjjlLXhGeffdamFocepSO3Se/evenZsyevvvoqAC6Xi5SUFMaNG8fDDz9sc+vEXx5//HGmT59Oenq63U0RmzgcDj799FOGDx8OmNGmxo0b88ADD/Dggw8CkJubS2JiIlOmTOH666+3sbXiS6f3BTAjTjk5OWeMREnNtm/fPhISEpg/fz79+vUjNzeX+Ph4pk2bxjXXXAPA+vXr6dChA0uXLuX888+3ucXiC6f3AzAjTueeey4vvfSSvY0LURpxskFRURErV65k0KBBp55zOp0MGjSIpUuX2tgyscPGjRtp3LgxrVq14sYbb2T79u12N0lstGXLFvbs2VPq+lCvXj169+6t60OImjdvHgkJCaSmpnL33Xdz4MABu5skPpabmwtAXFwcACtXruT48eOlrgvt27enWbNmui7UYKf3A7f33nuPRo0a0alTJx555BGOHDliR/NCUrjdDQhF+/fv5+TJkyQmJpZ6PjExkfXr19vUKrFD7969mTJlCqmpqezevZsnnniCiy66iDVr1hATE2N388QGe/bsASjz+uD+mYSOoUOHMmLECFq2bElmZiZ//OMfSUtLY+nSpYSFhdndPPEBl8vF+PHjueCCC+jUqRNgrguRkZHUr1+/1L66LtRcZfUDgJEjR9K8eXMaN27Mzz//zB/+8AcyMjL45JNPbGxt6FDgJGKjtLS0U9tdunShd+/eNG/enA8//JDRo0fb2DIRCQS/nprZuXNnunTpQuvWrZk3bx4DBw60sWXiK/feey9r1qzRetcQd7Z+cOedd57a7ty5M8nJyQwcOJDMzExat27t72aGHE3Vs0GjRo0ICws7IxtOdnY2SUlJNrVKAkH9+vVp164dmzZtsrspYhP3NUDXBylLq1ataNSoka4RNdTYsWOZMWMGc+fOpWnTpqeeT0pKoqioiJycnFL767pQM52tH5Sld+/eALom+IkCJxtERkbSo0cP5syZc+o5l8vFnDlz6NOnj40tE7sVFBSQmZlJcnKy3U0Rm7Rs2ZKkpKRS14e8vDy+//57XR+EHTt2cODAAV0jahjLshg7diyffvop3333HS1btiz18x49ehAREVHqupCRkcH27dt1XahBPPWDsriTS+ma4B+aqmeTCRMmcMstt3DeeefRq1cvXnrpJQ4fPsytt95qd9PEjx588EGuuOIKmjdvzq5du3jssccICwvjhhtusLtp4kMFBQWl7g5u2bKF9PR04uLiaNasGePHj+fJJ5+kbdu2tGzZkr/85S80bty4VLY1qRnK6wtxcXE88cQTXH311SQlJZGZmcnEiRNp06YNQ4YMsbHV4m333nsv06ZN47PPPiMmJubUuqV69epRu3Zt6tWrx+jRo5kwYQJxcXHExsYybtw4+vTpo4x6NYinfpCZmcm0adMYNmwYDRs25Oeff+b++++nX79+dOnSxebWhwhLbPPKK69YzZo1syIjI61evXpZy5Yts7tJ4mfXXXedlZycbEVGRlpNmjSxrrvuOmvTpk12N0t8bO7cuRZwxtctt9xiWZZluVwu6y9/+YuVmJhoRUVFWQMHDrQyMjLsbbT4RHl94ciRI9bgwYOt+Ph4KyIiwmrevLl1xx13WHv27LG72eJlZfUBwHrrrbdO7XP06FHrnnvusRo0aGDVqVPH+s1vfmPt3r3bvkaL13nqB9u3b7f69etnxcXFWVFRUVabNm2shx56yMrNzbW34SFEdZxEREREREQ80BonERERERERDxQ4iYiIiIiIeKDASURERERExAMFTiIiIiIiIh4ocBIREREREfFAgZOIiIiIiIgHCpxEREREREQ8UOAkIiIiIiLigQInERERERERDxQ4iYhI0Bk1ahTDhw+3uxkiIhJCFDiJiIhUU1FRkd1NEBERH1PgJCIiNcqkSZPo3Lkz0dHRpKSkcM8991BQUADA4cOHiY2N5aOPPir1munTpxMdHU1+fj4AWVlZXHvttdSvX5+4uDiuuuoqtm7demp/94jX3/72Nxo3bkxqaqrf/n0iImIPBU4iIlKjOJ1OXn75ZdauXcvbb7/Nd999x8SJEwGIjo7m+uuv56233ir1mrfeeotrrrmGmJgYjh8/zpAhQ4iJiWHhwoUsXryYunXrMnTo0FIjS3PmzCEjI4NZs2YxY8YMv/4bRUTE/xyWZVl2N0JERKQyRo0aRU5ODtOnT/e470cffcSYMWPYv38/AMuXL6dv375kZWWRnJzM3r17adKkCbNnz6Z///68++67PPnkk/zyyy84HA7ATMWrX78+06dPZ/DgwYwaNYqZM2eyfft2IiMjfflPFRGRAKERJxERqVFmz57NwIEDadKkCTExMdx8880cOHCAI0eOANCrVy86duzI22+/DcC7775L8+bN6devHwCrVq1i06ZNxMTEULduXerWrUtcXByFhYVkZmaeOk/nzp0VNImIhBAFTiIiUmNs3bqVyy+/nC5duvDxxx+zcuVKJk+eDJRO4HD77bczZcoUwEzTu/XWW0+NLhUUFNCjRw/S09NLfW3YsIGRI0eeOkZ0dLT//mEiImK7cLsbICIi4i0rV67E5XLxwgsv4HSae4MffvjhGfvddNNNTJw4kZdffpl169Zxyy23nPpZ9+7d+eCDD0hISCA2NtZvbRcRkcCmEScREQlKubm5Z4wKNWrUiOPHj/PKK6+wefNmpk6dyuuvv37Gaxs0aMCIESN46KGHGDx4ME2bNj31sxtvvJFGjRpx1VVXsXDhQrZs2cK8efO477772LFjhz//iSIiEkAUOImISFCaN28e3bp1K/U1depUJk2axDPPPEOnTp147733eOqpp8p8/ejRoykqKuK2224r9XydOnVYsGABzZo1Y8SIEXTo0IHRo0dTWFioESgRkRCmrHoiIhKSpk6dyv3338+uXbuU5EFERDzSGicREQkpR44cYffu3Tz99NPcddddCppERKRCNFVPRERCyrPPPkv79u1JSkrikUcesbs5IiISJDRVT0RERERExAONOImIiIiIiHigwElERERERMQDBU4iIiIiIiIeKHASERERERHxQIGTiIiIiIiIBwqcREREREREPFDgJCIiIiIi4oECJxEREREREQ/+P2hX07WTu5kHAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 1000x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# What Fisher scores look like \n",
    "\n",
    "with open(\"scores/llama_3b_scores.json\", 'r') as f:\n",
    "    data = json.load(f)\n",
    "\n",
    "def display(dataset_1, dataset_2, metric=\"fisher_separability\"):\n",
    "    mlp_data = data[f\"mlp_{dataset_1}_vs_{dataset_2}_{metric}\"]\n",
    "    attn_data = data[f\"attn_{dataset_1}_vs_{dataset_2}_{metric}\"]\n",
    "    attn_layer_ranks = sorted(range(len(attn_data)), key=lambda i: attn_data[i], reverse=True)\n",
    "    print(\"Ranking acc to attn: \", attn_layer_ranks)\n",
    "    mlp_layer_ranks = sorted(range(len(mlp_data)), key=lambda i: mlp_data[i], reverse=True)\n",
    "    print(\"Ranking acc to mlp: \", mlp_layer_ranks)\n",
    "    plt.figure(figsize=(10,5))\n",
    "    plt.plot(mlp_data, label=\"MLP\", marker=\"o\")\n",
    "    plt.plot(attn_data, label=\"Attention\", marker=\"s\")\n",
    "    plt.xlabel(\"Layer\")\n",
    "    plt.ylabel(\"Fisher Separability\")\n",
    "    plt.title(f\"Fisher Separability Across Layers ({dataset_1.upper()} vs {dataset_2.upper()})\")\n",
    "    plt.legend()\n",
    "    plt.grid(True, alpha=0.3)\n",
    "    plt.show()\n",
    "    \n",
    "display(\"cpp_top\", \"python_top\")\n",
    "display(\"science\", \"math\")\n",
    "display(\"medical\", \"finance\")\n",
    "def layer_rank(dataset_1, dataset_2, metric=\"fisher_separability\", descending=True):\n",
    "    mlp_data = data[f\"mlp_{dataset_1}_vs_{dataset_2}_{metric}\"]\n",
    "    attn_data = data[f\"attn_{dataset_1}_vs_{dataset_2}_{metric}\"]\n",
    "    attn_layer_ranks = sorted(range(len(attn_data)), key=lambda i: attn_data[i], reverse=descending)\n",
    "    print(\"Ranking acc to attn: \", attn_layer_ranks)\n",
    "    mlp_layer_ranks = sorted(range(len(mlp_data)), key=lambda i: mlp_data[i], reverse=descending)\n",
    "    print(\"Ranking acc to mlp: \", mlp_layer_ranks)\n",
    "    return attn_layer_ranks, mlp_layer_ranks\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T16:40:13.335438Z",
     "iopub.status.busy": "2025-09-24T16:40:13.335320Z",
     "iopub.status.idle": "2025-09-24T16:40:13.340545Z",
     "shell.execute_reply": "2025-09-24T16:40:13.340201Z"
    }
   },
   "outputs": [],
   "source": [
    "def inspect_layers(model_dict, config, block_type, layers, test_name=\"\"):\n",
    "    LAYERS = []\n",
    "    for index in layers:\n",
    "        LAYERS.append(LayerSpec(block_type, index))\n",
    "    crosswap_results = run_cross_swap_batch(model_dict, config, LAYERS)\n",
    "    # print(crosswap_results)\n",
    "    return crosswap_results\n",
    "\n",
    "\n",
    "def layer_rank(dataset_1: str, dataset_2: str, data: dict, metric=\"fisher_separability\", descending=True):\n",
    "    \"\"\"\n",
    "    Ranks layers based on a given metric from the data dictionary.\n",
    "    \n",
    "    Args:\n",
    "        dataset_1: Name of the first dataset.\n",
    "        dataset_2: Name of the second dataset.\n",
    "        data: The dictionary containing the pre-computed metric scores.\n",
    "        metric: The metric to use for ranking.\n",
    "        descending: If True, higher scores are better.\n",
    "        \n",
    "    Returns:\n",
    "        A tuple of (attn_layer_ranks, mlp_layer_ranks).\n",
    "    \"\"\"\n",
    "    # Construct the keys to access the metric data\n",
    "\n",
    "    mlp_key = f\"mlp_{dataset_1}_vs_{dataset_2}_{metric}\"\n",
    "    attn_key = f\"attn_{dataset_1}_vs_{dataset_2}_{metric}\"\n",
    "    \n",
    "    # Check if data exists\n",
    "    if mlp_key not in data or attn_key not in data:\n",
    "        raise KeyError(f\"Metric data for '{mlp_key}' or '{attn_key}' not found in data dictionary.\")\n",
    "\n",
    "    mlp_data = data[mlp_key]\n",
    "    attn_data = data[attn_key]\n",
    "    \n",
    "    # Sort layer indices based on their corresponding metric value\n",
    "    attn_layer_ranks = sorted(range(1, len(attn_data)), key=lambda i: attn_data[i], reverse=descending)\n",
    "    mlp_layer_ranks = sorted(range(1, len(mlp_data)), key=lambda i: mlp_data[i], reverse=descending)\n",
    "    \n",
    "    print(f\"Ranking for {dataset_1} vs {dataset_2} (metric: {metric}):\")\n",
    "    print(f\"  - ATTN ranks: {attn_layer_ranks}\")\n",
    "    print(f\"  - MLP ranks:  {mlp_layer_ranks}\\n\")\n",
    "    \n",
    "    return attn_layer_ranks, mlp_layer_ranks\n",
    "\n",
    "def run_top_bottom_layer_analysis(model_dict, config_dict: dict, metric=\"fisher_separability\"):\n",
    "    \"\"\"\n",
    "    Finds top/bottom 5 layers for each config, runs inspection, and returns results.\n",
    "\n",
    "    Args:\n",
    "        config_dict: A dictionary where keys are experiment names and values are config objects.\n",
    "                     Each config object must have 'a.name' and 'b.name' attributes.\n",
    "        data: The dictionary containing the pre-computed metric scores for ranking.\n",
    "        metric: The metric to use for ranking layers.\n",
    "\n",
    "    Returns:\n",
    "        A nested dictionary containing the results from `inspect_layers` for each\n",
    "        group (top_5_attn, bottom_5_attn, etc.) for each configuration.\n",
    "    \"\"\"\n",
    "    with open(model_dict[\"data_path\"], 'r') as f:\n",
    "        data = json.load(f)\n",
    "    all_results = {}\n",
    "\n",
    "    for config_name, config in config_dict.items():\n",
    "        print(f\"--- Processing configuration: {config_name} ---\")\n",
    "        all_results[config_name] = {}\n",
    "        \n",
    "        # Step 1: Get the fully ranked layers for the current config\n",
    "        d1 = config.a.name\n",
    "        d2 = config.b.name\n",
    "        attn_ranks, mlp_ranks = layer_rank(d1, d2, data, metric=metric)\n",
    "        \n",
    "        # Step 2: Get the top 5 and bottom 5 layers for both ATTN and MLP\n",
    "        # Slicing handles cases where there are fewer than 10 layers\n",
    "        layer_groups = {\n",
    "            \"top_5_attn\": attn_ranks[:5],\n",
    "            \"bottom_5_attn\": attn_ranks[-5:],\n",
    "            \"top_5_mlp\": mlp_ranks[:5],\n",
    "            \"bottom_5_mlp\": mlp_ranks[-5:]\n",
    "        }\n",
    "        \n",
    "        # Step 3: Loop through the 4 groups and run the inspection function\n",
    "        for group_name, layers in layer_groups.items():\n",
    "            if not layers:\n",
    "                print(f\"Skipping '{group_name}' for '{config_name}' as no layers were found.\")\n",
    "                continue\n",
    "\n",
    "            print(f\"Running inspection for '{group_name}' with layers: {layers}\")\n",
    "            \n",
    "            block_type = \"attn\" if \"attn\" in group_name else \"mlp\"\n",
    "            \n",
    "            # Call the provided inspection function\n",
    "            \n",
    "            group_results = inspect_layers(\n",
    "                model_dict=model_dict,\n",
    "                config=config,\n",
    "                block_type=block_type,\n",
    "                layers=layers,\n",
    "                test_name=group_name\n",
    "            )\n",
    "            # print(f\"Results for {config_name} and {group_name}\")\n",
    "            # print(group_results)\n",
    "            \n",
    "            all_results[config_name][group_name] = group_results\n",
    "            \n",
    "    print(\"\\n--- Analysis Complete ---\")\n",
    "    return all_results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T16:40:13.341566Z",
     "iopub.status.busy": "2025-09-24T16:40:13.341467Z",
     "iopub.status.idle": "2025-09-24T16:40:13.346599Z",
     "shell.execute_reply": "2025-09-24T16:40:13.346251Z"
    }
   },
   "outputs": [],
   "source": [
    "def plot_block_type_results(experiment_data, block_type, side_names, main_title, model_name):\n",
    "    \"\"\"\n",
    "    Generates grouped bar charts for a specific block type (attn or mlp).\n",
    "\n",
    "    Args:\n",
    "        experiment_data (dict): The dictionary for one experiment (e.g., data['cpp-python']).\n",
    "        block_type (str): The type of block to plot ('attn' or 'mlp').\n",
    "        side_names (tuple): Tuple of the two side names (e.g., ('cpp', 'python')).\n",
    "        main_title (str): The overall title for the figure.\n",
    "    \"\"\"\n",
    "    side_a_name, side_b_name = side_names\n",
    "\n",
    "    # Filter data to only include categories for the specified block_type\n",
    "    filtered_data = {\n",
    "        key: value\n",
    "        for key, value in experiment_data.items()\n",
    "        if block_type in key\n",
    "    }\n",
    "    \n",
    "    if not filtered_data:\n",
    "        print(f\"No data found for block type '{block_type}' in the provided experiment.\")\n",
    "        return\n",
    "\n",
    "    # Create a figure with two subplots: one for KL, one for shift_other\n",
    "    fig, (ax1, ax2) = plt.subplots(1, 2, figsize=(15, 8))\n",
    "    fig.suptitle(main_title, fontsize=18)\n",
    "\n",
    "    axes = {'KL': ax1, 'shift_other': ax2}\n",
    "    \n",
    "    for metric, ax in axes.items():\n",
    "        all_labels = []\n",
    "        all_means_a = []\n",
    "        all_stds_a = []\n",
    "        all_means_b = []\n",
    "        all_stds_b = []\n",
    "        \n",
    "        # Iterate through the filtered categories (e.g., top_5_attn, bottom_5_attn)\n",
    "        for category_name, layers_data in filtered_data.items():\n",
    "            layer_names = list(layers_data.keys())\n",
    "            all_labels.extend(layer_names)\n",
    "            \n",
    "            all_means_a.extend([layers_data[layer][side_a_name][metric]['mean'] for layer in layer_names])\n",
    "            all_stds_a.extend([layers_data[layer][side_a_name][metric]['std'] for layer in layer_names])\n",
    "            all_means_b.extend([layers_data[layer][side_b_name][metric]['mean'] for layer in layer_names])\n",
    "            all_stds_b.extend([layers_data[layer][side_b_name][metric]['std'] for layer in layer_names])\n",
    "\n",
    "        # Plotting logic\n",
    "        x = np.arange(len(all_labels))\n",
    "        width = 0.35\n",
    "\n",
    "        ax.bar(x - width/2, all_means_a, width, label=side_a_name.upper(), yerr=all_stds_a, capsize=5, alpha=0.8)\n",
    "        ax.bar(x + width/2, all_means_b, width, label=side_b_name.upper(), yerr=all_stds_b, capsize=5, alpha=0.8)\n",
    "\n",
    "        # Add text, labels, and title\n",
    "        ax.set_ylabel(metric, fontsize=12)\n",
    "        ax.set_title(f'Comparison of {metric} Metric', fontsize=14)\n",
    "        ax.set_xticks(x)\n",
    "        ax.set_xticklabels(all_labels, rotation=45, ha=\"right\", fontsize=10)\n",
    "        ax.legend()\n",
    "        ax.grid(axis='y', linestyle='--', alpha=0.7)\n",
    "        \n",
    "        # Add a single vertical line between the 'top_5' and 'bottom_5' categories\n",
    "        if len(filtered_data) > 1:\n",
    "            # The line should be after the first group of bars\n",
    "            separator_pos = len(list(filtered_data.values())[0]) - 0.5\n",
    "            ax.axvline(separator_pos, color='grey', linestyle='--')\n",
    "    save_dir = f\"cvp_results_imgs/{model_name}\"\n",
    "    os.makedirs(save_dir, exist_ok=True) \n",
    "    plt.tight_layout(rect=(0.0, 0.03, 1.0, 0.95))\n",
    "    plt.savefig(f\"{save_dir}/{block_type}_{side_names[0]}_{side_names[1]}.png\", dpi=300, bbox_inches=\"tight\")\n",
    "    plt.show()\n",
    "\n",
    "\n",
    "# with open(\"cvp-2-results2.json\", 'r') as f:\n",
    "#     shift_data = json.load(f)\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T16:40:13.347611Z",
     "iopub.status.busy": "2025-09-24T16:40:13.347514Z",
     "iopub.status.idle": "2025-09-24T16:40:13.357260Z",
     "shell.execute_reply": "2025-09-24T16:40:13.356783Z"
    }
   },
   "outputs": [],
   "source": [
    "\n",
    "def run_kl_analysis(model_dict, config_dict, metric=\"fisher_separability\"):\n",
    "\n",
    "    with open(model_dict[\"data_path\"], 'r') as f:\n",
    "        data = json.load(f)\n",
    "    all_results = {}\n",
    "\n",
    "    for config_name, config in config_dict.items():\n",
    "        print(f\"--- Processing configuration: {config_name} ---\")\n",
    "        all_results[config_name] = {}\n",
    "        \n",
    "        # Step 1: Get the fully ranked layers for the current config\n",
    "        d1 = config.a.name\n",
    "        d2 = config.b.name\n",
    "        attn_ranks, mlp_ranks = layer_rank(d1, d2, data, metric=metric)\n",
    "        \n",
    "        # Step 2: Get the top 5 and bottom 5 layers for both ATTN and MLP\n",
    "        # Slicing handles cases where there are fewer than 10 layers\n",
    "        layer_groups = {\n",
    "            \"top_5_attn\": attn_ranks[:5],\n",
    "            \"bottom_5_attn\": attn_ranks[-5:],\n",
    "            \"top_5_mlp\": mlp_ranks[:5],\n",
    "            \"bottom_5_mlp\": mlp_ranks[-5:]\n",
    "        }\n",
    "        \n",
    "        # Step 3: Loop through the 4 groups and run the inspection function\n",
    "        for group_name, layers in layer_groups.items():\n",
    "            if not layers:\n",
    "                print(f\"Skipping '{group_name}' for '{config_name}' as no layers were found.\")\n",
    "                continue\n",
    "\n",
    "            print(f\"Running inspection for '{group_name}' with layers: {layers}\")\n",
    "            \n",
    "            block_type = \"attn\" if \"attn\" in group_name else \"mlp\"\n",
    "            \n",
    "            # Call the provided inspection function\n",
    "            \n",
    "            group_results = inspect_layers(\n",
    "                model_dict=model_dict,\n",
    "                config=config,\n",
    "                block_type=block_type,\n",
    "                layers=layers,\n",
    "                test_name=group_name\n",
    "            )\n",
    "            # print(f\"Results for {config_name} and {group_name}\")\n",
    "            # print(group_results)\n",
    "            \n",
    "            all_results[config_name][group_name] = group_results\n",
    "            \n",
    "    print(\"\\n--- Analysis Complete ---\")\n",
    "    return all_results\n",
    "def compute_kl(model_path, model_name, config_dict):\n",
    "    \"\"\"\n",
    "    Loads a model, runs analysis, unloads it to free GPU memory,\n",
    "    and then processes the results.\n",
    "    \"\"\"\n",
    "\n",
    "    results = None\n",
    "    model = None\n",
    "    tokenizer = None\n",
    "    model_dict = None\n",
    "\n",
    "    try:\n",
    "        # =================================================================\n",
    "        # PART 1: LOAD MODEL AND RUN ANALYSIS (GPU HEAVY)\n",
    "        # =================================================================\n",
    "        print(f\"--- Starting analysis for {model_name} ---\")\n",
    "        memory_before = torch.cuda.memory_allocated(DEVICE) / 1024**3\n",
    "        print(f\"GPU memory allocated before load: {memory_before:.2f} GB\")\n",
    "        if \"gemma_4b\" in model_name.lower():\n",
    "            DTYPE = torch.bfloat16\n",
    "        else:\n",
    "            DTYPE = torch.float16\n",
    "        tokenizer = AutoTokenizer.from_pretrained(model_path, token=HF_TOKEN, use_fast=True)\n",
    "        if tokenizer.pad_token is None:\n",
    "            tokenizer.pad_token = tokenizer.eos_token\n",
    "\n",
    "        model = AutoModelForCausalLM.from_pretrained(\n",
    "            model_path, token=HF_TOKEN, torch_dtype=DTYPE, low_cpu_mem_usage=True\n",
    "        ).to(DEVICE).eval()\n",
    "\n",
    "        memory_after = torch.cuda.memory_allocated(DEVICE) / 1024**3\n",
    "        print(f\"GPU memory allocated after load:  {memory_after:.2f} GB\")\n",
    "\n",
    "        # Simplified logic to get the number of layers\n",
    "        if \"gemma_4b\" in model_name.lower():\n",
    "            num_layers = len(model.model.language_model.layers)\n",
    "        else:  # Assuming Llama-like structure\n",
    "            num_layers = len(model.model.layers)\n",
    "\n",
    "        model_dict = {\n",
    "            \"model\": model,\n",
    "            \"tokenizer\": tokenizer,\n",
    "            \"layers\": num_layers,\n",
    "            \"data_path\": f\"scores/{model_name}_scores.json\"\n",
    "        }\n",
    "\n",
    "        # This is where all the GPU computation should happen\n",
    "        results = run_kl_analysis(model_dict, config_dict)\n",
    "        print(\"Analysis complete.\")\n",
    "\n",
    "    finally:\n",
    "        # =================================================================\n",
    "        # PART 2: UNLOAD MODEL AND CLEAR GPU MEMORY\n",
    "        # =================================================================\n",
    "        print(\"\\nUnloading model and clearing GPU memory...\")\n",
    "        \n",
    "        # Explicitly delete all large objects that have references to the model\n",
    "        del model_dict\n",
    "        del model\n",
    "        del tokenizer\n",
    "        \n",
    "        # Force garbage collection and empty CUDA cache\n",
    "        gc.collect()\n",
    "        torch.cuda.empty_cache()\n",
    "\n",
    "        memory_final = torch.cuda.memory_allocated(DEVICE) / 1024**3\n",
    "        print(f\"GPU memory allocated after unload: {memory_final:.2f} GB\")\n",
    "        print(\"--- GPU intensive tasks finished ---\")\n",
    "        # 1. Define the directory name you want\n",
    "        save_dir = \"full_compute\"\n",
    "        os.makedirs(save_dir, exist_ok=True) \n",
    "        filepath = os.path.join(save_dir, f\"{model_name}.json\")\n",
    "        with open(filepath, \"w\") as f:\n",
    "            json.dump(results, f)\n",
    "            \n",
    "def run_model_analysis_and_unload(model_path, model_name, config_dict):\n",
    "    \"\"\"\n",
    "    Loads a model, runs analysis, unloads it to free GPU memory,\n",
    "    and then processes the results.\n",
    "    \"\"\"\n",
    "    results = None\n",
    "    model = None\n",
    "    tokenizer = None\n",
    "    model_dict = None\n",
    "\n",
    "    try:\n",
    "        # =================================================================\n",
    "        # PART 1: LOAD MODEL AND RUN ANALYSIS (GPU HEAVY)\n",
    "        # =================================================================\n",
    "        print(f\"--- Starting analysis for {model_name} ---\")\n",
    "        memory_before = torch.cuda.memory_allocated(DEVICE) / 1024**3\n",
    "        print(f\"GPU memory allocated before load: {memory_before:.2f} GB\")\n",
    "        if \"gemma_4b\" in model_name.lower():\n",
    "            DTYPE = torch.bfloat16\n",
    "        else:\n",
    "            DTYPE = torch.float16\n",
    "        tokenizer = AutoTokenizer.from_pretrained(model_path, token=HF_TOKEN, use_fast=True)\n",
    "        if tokenizer.pad_token is None:\n",
    "            tokenizer.pad_token = tokenizer.eos_token\n",
    "\n",
    "        model = AutoModelForCausalLM.from_pretrained(\n",
    "            model_path, token=HF_TOKEN, torch_dtype=DTYPE, low_cpu_mem_usage=True\n",
    "        ).to(DEVICE).eval()\n",
    "\n",
    "        memory_after = torch.cuda.memory_allocated(DEVICE) / 1024**3\n",
    "        print(f\"GPU memory allocated after load:  {memory_after:.2f} GB\")\n",
    "\n",
    "        # Simplified logic to get the number of layers\n",
    "        if \"gemma_4b\" in model_name.lower():\n",
    "            num_layers = len(model.model.language_model.layers)\n",
    "        else:  # Assuming Llama-like structure\n",
    "            num_layers = len(model.model.layers)\n",
    "\n",
    "        model_dict = {\n",
    "            \"model\": model,\n",
    "            \"tokenizer\": tokenizer,\n",
    "            \"layers\": num_layers,\n",
    "            \"data_path\": f\"scores/{model_name}_scores.json\"\n",
    "        }\n",
    "\n",
    "        # This is where all the GPU computation should happen\n",
    "        results = run_top_bottom_layer_analysis(model_dict, config_dict)\n",
    "        print(\"Analysis complete.\")\n",
    "\n",
    "    finally:\n",
    "        # =================================================================\n",
    "        # PART 2: UNLOAD MODEL AND CLEAR GPU MEMORY\n",
    "        # =================================================================\n",
    "        print(\"\\nUnloading model and clearing GPU memory...\")\n",
    "        \n",
    "        # Explicitly delete all large objects that have references to the model\n",
    "        del model_dict\n",
    "        del model\n",
    "        del tokenizer\n",
    "        \n",
    "        # Force garbage collection and empty CUDA cache\n",
    "        gc.collect()\n",
    "        torch.cuda.empty_cache()\n",
    "\n",
    "        memory_final = torch.cuda.memory_allocated(DEVICE) / 1024**3\n",
    "        print(f\"GPU memory allocated after unload: {memory_final:.2f} GB\")\n",
    "        print(\"--- GPU intensive tasks finished ---\")\n",
    "\n",
    "    # =================================================================\n",
    "    # PART 3: PROCESS RESULTS (CPU & DISK HEAVY)\n",
    "    # =================================================================\n",
    "    # This part only runs after the model is confirmed to be off the GPU.\n",
    "    if results is not None:\n",
    "        print(\"\\nProcessing and saving results...\")\n",
    "        save_dir = \"model_cvp_results\"\n",
    "        os.makedirs(save_dir, exist_ok=True)\n",
    "        \n",
    "        results_path = f\"{save_dir}/{model_name}.json\"\n",
    "        with open(results_path, 'w') as f:\n",
    "            json.dump(results, f)\n",
    "\n",
    "        with open(results_path, 'r') as f:\n",
    "            shift_data = json.load(f)\n",
    "\n",
    "        plot_block_type_results(\n",
    "            experiment_data=shift_data['cpp-python'],\n",
    "            block_type='mlp',\n",
    "            side_names=('cpp_top', 'python_top'),\n",
    "            main_title='Analysis of C++ vs. Python Data',\n",
    "            model_name=model_name\n",
    "        )\n",
    "        plot_block_type_results(\n",
    "            experiment_data=shift_data['cpp-python'],\n",
    "            block_type='attn',\n",
    "            side_names=('cpp_top', 'python_top'),\n",
    "            main_title='Analysis of C++ vs. Python Data',\n",
    "            model_name=model_name\n",
    "        )\n",
    "        print(\"Result processing and plotting complete.\")\n",
    "    else:\n",
    "        print(\"No results were generated, skipping post-processing.\")\n",
    "\n",
    "    \n",
    "    \n",
    "    \n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T16:40:13.358345Z",
     "iopub.status.busy": "2025-09-24T16:40:13.358244Z",
     "iopub.status.idle": "2025-09-24T16:45:55.984274Z",
     "shell.execute_reply": "2025-09-24T16:45:55.983452Z"
    }
   },
   "outputs": [],
   "source": [
    "model_path = \"google/gemma-3-4b-it\"\n",
    "model_name = \"gemma_4b\"\n",
    "compute_kl(model_path, model_name, config_dict)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T16:45:55.986249Z",
     "iopub.status.busy": "2025-09-24T16:45:55.986031Z",
     "iopub.status.idle": "2025-09-24T16:50:04.050390Z",
     "shell.execute_reply": "2025-09-24T16:50:04.049629Z"
    }
   },
   "outputs": [],
   "source": [
    "model_path = \"meta-llama/Llama-3.2-3B\"\n",
    "model_name = \"llama_3b\"\n",
    "compute_kl(model_path, model_name, config_dict)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T16:50:04.052627Z",
     "iopub.status.busy": "2025-09-24T16:50:04.052510Z",
     "iopub.status.idle": "2025-09-24T16:53:43.807199Z",
     "shell.execute_reply": "2025-09-24T16:53:43.806755Z"
    }
   },
   "outputs": [],
   "source": [
    "model_path = \"google/gemma-3-1b-it\"\n",
    "model_name = \"gemma_1b\"\n",
    "compute_kl(model_path, model_name, config_dict)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T16:53:43.808756Z",
     "iopub.status.busy": "2025-09-24T16:53:43.808642Z",
     "iopub.status.idle": "2025-09-24T16:55:33.666256Z",
     "shell.execute_reply": "2025-09-24T16:55:33.665151Z"
    }
   },
   "outputs": [],
   "source": [
    "model_path = \"meta-llama/Llama-3.2-1B\"\n",
    "model_name = \"llama_1b\"\n",
    "compute_kl(model_path, model_name, config_dict)"
   ]
  }
 ],
 "metadata": {
  "kaggle": {
   "accelerator": "nvidiaTeslaT4",
   "dataSources": [
    {
     "datasetId": 7704802,
     "sourceId": 12228781,
     "sourceType": "datasetVersion"
    }
   ],
   "dockerImageVersionId": 31090,
   "isGpuEnabled": true,
   "isInternetEnabled": true,
   "language": "python",
   "sourceType": "notebook"
  },
  "kernelspec": {
   "display_name": "causal",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.12"
  },
  "widgets": {
   "application/vnd.jupyter.widget-state+json": {
    "state": {
     "04967b6f552f4dd1a393ea40b3209989": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "ProgressStyleModel",
      "state": {
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "ProgressStyleModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "StyleView",
       "bar_color": null,
       "description_width": ""
      }
     },
     "051bcc06a84a4deb9c1cc0a2fbaa8d7f": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "2.0.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border_bottom": null,
       "border_left": null,
       "border_right": null,
       "border_top": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     },
     "23e751f9c8a6407bbf1d0b05d369473a": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "ProgressStyleModel",
      "state": {
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "ProgressStyleModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "StyleView",
       "bar_color": null,
       "description_width": ""
      }
     },
     "3f201d92c57b45c4aa1912a592554c37": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HTMLModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "2.0.0",
       "_view_name": "HTMLView",
       "description": "",
       "description_allow_html": false,
       "layout": "IPY_MODEL_eb506903aedc422e9f539e9ccb59aaea",
       "placeholder": "​",
       "style": "IPY_MODEL_489f08596b75408f995f82a3e8d42d24",
       "tabbable": null,
       "tooltip": null,
       "value": " 2/2 [00:00&lt;00:00,  3.30it/s]"
      }
     },
     "489f08596b75408f995f82a3e8d42d24": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLStyleModel",
      "state": {
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HTMLStyleModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "StyleView",
       "background": null,
       "description_width": "",
       "font_size": null,
       "text_color": null
      }
     },
     "5128e978083f4d0791afc7bbc7637a4b": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HBoxModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HBoxModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "2.0.0",
       "_view_name": "HBoxView",
       "box_style": "",
       "children": [
        "IPY_MODEL_cd09fdfc5abe45cd8935a0166b0b2c80",
        "IPY_MODEL_9415b08b1d464f64ad47e3f559aaf9e2",
        "IPY_MODEL_3f201d92c57b45c4aa1912a592554c37"
       ],
       "layout": "IPY_MODEL_bbd4ac828b654bdb886a51d2f5c3f074",
       "tabbable": null,
       "tooltip": null
      }
     },
     "57c5e438015a4a76a777efd5db09b20f": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "2.0.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border_bottom": null,
       "border_left": null,
       "border_right": null,
       "border_top": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     },
     "7e66d3bf0f774690a01ded1dbfa9b481": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "2.0.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border_bottom": null,
       "border_left": null,
       "border_right": null,
       "border_top": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     },
     "7ee0078c505a4e4fb6f9f9901da92fff": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HTMLModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "2.0.0",
       "_view_name": "HTMLView",
       "description": "",
       "description_allow_html": false,
       "layout": "IPY_MODEL_57c5e438015a4a76a777efd5db09b20f",
       "placeholder": "​",
       "style": "IPY_MODEL_e7246f5411574210b26e8d04430a6ed2",
       "tabbable": null,
       "tooltip": null,
       "value": "Loading checkpoint shards: 100%"
      }
     },
     "8da0235fa66941229c8e07be219f533f": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "2.0.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border_bottom": null,
       "border_left": null,
       "border_right": null,
       "border_top": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     },
     "93995a494d6a4778bff4b32b292378f3": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "2.0.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border_bottom": null,
       "border_left": null,
       "border_right": null,
       "border_top": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     },
     "9415b08b1d464f64ad47e3f559aaf9e2": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "FloatProgressModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "FloatProgressModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "2.0.0",
       "_view_name": "ProgressView",
       "bar_style": "success",
       "description": "",
       "description_allow_html": false,
       "layout": "IPY_MODEL_7e66d3bf0f774690a01ded1dbfa9b481",
       "max": 2,
       "min": 0,
       "orientation": "horizontal",
       "style": "IPY_MODEL_04967b6f552f4dd1a393ea40b3209989",
       "tabbable": null,
       "tooltip": null,
       "value": 2
      }
     },
     "a83288e3f785495f9e7ed40591c5dc92": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "FloatProgressModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "FloatProgressModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "2.0.0",
       "_view_name": "ProgressView",
       "bar_style": "success",
       "description": "",
       "description_allow_html": false,
       "layout": "IPY_MODEL_93995a494d6a4778bff4b32b292378f3",
       "max": 2,
       "min": 0,
       "orientation": "horizontal",
       "style": "IPY_MODEL_23e751f9c8a6407bbf1d0b05d369473a",
       "tabbable": null,
       "tooltip": null,
       "value": 2
      }
     },
     "b5ae51b495ad4b22b2a816fddd6055b4": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "2.0.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border_bottom": null,
       "border_left": null,
       "border_right": null,
       "border_top": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     },
     "bbd4ac828b654bdb886a51d2f5c3f074": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "2.0.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border_bottom": null,
       "border_left": null,
       "border_right": null,
       "border_top": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     },
     "cd09fdfc5abe45cd8935a0166b0b2c80": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HTMLModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "2.0.0",
       "_view_name": "HTMLView",
       "description": "",
       "description_allow_html": false,
       "layout": "IPY_MODEL_051bcc06a84a4deb9c1cc0a2fbaa8d7f",
       "placeholder": "​",
       "style": "IPY_MODEL_f2ad87fd7316407ea2fcba817a1116d4",
       "tabbable": null,
       "tooltip": null,
       "value": "Loading checkpoint shards: 100%"
      }
     },
     "d54729f5dcfb4f65a8718b472d8a4afb": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HBoxModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HBoxModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "2.0.0",
       "_view_name": "HBoxView",
       "box_style": "",
       "children": [
        "IPY_MODEL_7ee0078c505a4e4fb6f9f9901da92fff",
        "IPY_MODEL_a83288e3f785495f9e7ed40591c5dc92",
        "IPY_MODEL_f4c4a49e51eb43b29eac94b38d8e4c77"
       ],
       "layout": "IPY_MODEL_b5ae51b495ad4b22b2a816fddd6055b4",
       "tabbable": null,
       "tooltip": null
      }
     },
     "e7246f5411574210b26e8d04430a6ed2": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLStyleModel",
      "state": {
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HTMLStyleModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "StyleView",
       "background": null,
       "description_width": "",
       "font_size": null,
       "text_color": null
      }
     },
     "eb506903aedc422e9f539e9ccb59aaea": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "2.0.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border_bottom": null,
       "border_left": null,
       "border_right": null,
       "border_top": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     },
     "f2ad87fd7316407ea2fcba817a1116d4": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLStyleModel",
      "state": {
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HTMLStyleModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "StyleView",
       "background": null,
       "description_width": "",
       "font_size": null,
       "text_color": null
      }
     },
     "f4c4a49e51eb43b29eac94b38d8e4c77": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HTMLModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "2.0.0",
       "_view_name": "HTMLView",
       "description": "",
       "description_allow_html": false,
       "layout": "IPY_MODEL_8da0235fa66941229c8e07be219f533f",
       "placeholder": "​",
       "style": "IPY_MODEL_fe8cfe66ae9a45b298f49d5964cd37c8",
       "tabbable": null,
       "tooltip": null,
       "value": " 2/2 [00:00&lt;00:00,  9.03it/s]"
      }
     },
     "fe8cfe66ae9a45b298f49d5964cd37c8": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLStyleModel",
      "state": {
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HTMLStyleModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "StyleView",
       "background": null,
       "description_width": "",
       "font_size": null,
       "text_color": null
      }
     }
    },
    "version_major": 2,
    "version_minor": 0
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
