{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a60e5c83",
   "metadata": {},
   "outputs": [],
   "source": [
    "import gc\n",
    "import itertools\n",
    "import math\n",
    "import os\n",
    "import random\n",
    "import sys\n",
    "from collections import Counter, defaultdict\n",
    "from copy import deepcopy\n",
    "from dataclasses import dataclass\n",
    "from functools import partial\n",
    "from pathlib import Path\n",
    "from typing import Any, Callable, Literal, TypeAlias\n",
    "\n",
    "import einops\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import torch as t\n",
    "from datasets import load_dataset\n",
    "from IPython.display import clear_output, display\n",
    "from jaxtyping import Float, Int\n",
    "from rich import print as rprint\n",
    "from rich.table import Table\n",
    "\n",
    "from transformer_lens import HookedTransformer, HookedTransformerConfig\n",
    "from tabulate import tabulate\n",
    "from torch import Tensor, nn\n",
    "from torch.nn import functional as F\n",
    "from tqdm.auto import tqdm\n",
    "from transformer_lens import ActivationCache, loading_from_pretrained\n",
    "from transformer_lens.hook_points import HookPoint\n",
    "from transformer_lens.utils import get_act_name, to_numpy\n",
    "from transformer_lens import utils\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import torch\n",
    "\n",
    "from scipy.sparse import csr_array\n",
    "from scipy.sparse.csgraph import maximum_bipartite_matching, min_weight_full_bipartite_matching\n",
    "\n",
    "device = t.device(\"mps\" if t.backends.mps.is_available() else \"cuda\" if t.cuda.is_available() else \"cpu\")\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "407cca18",
   "metadata": {},
   "source": [
    "## Model & State_dict Loading "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "263081bd",
   "metadata": {},
   "outputs": [],
   "source": [
    "import importlib\n",
    "\n",
    "# ------------------- Specify Model Arch -------------------\n",
    "arch = \"l8_h8\"\n",
    "\n",
    "# ------------------- Load Model Config -------------------\n",
    "\n",
    "def load_named_config(module_name: str, config_name: str) -> dict:\n",
    "    \"\"\"\n",
    "    Import a module that defines CONFIGS: Dict[str, Dict[str, Any]]\n",
    "    and return CONFIGS[config_name].\n",
    "    \"\"\"\n",
    "    try:\n",
    "        mod = importlib.import_module(module_name)\n",
    "    except Exception as e:\n",
    "        raise ImportError(f\"Could not import config module '{module_name}': {e}\") from e\n",
    "\n",
    "    if not hasattr(mod, \"CONFIGS\"):\n",
    "        raise AttributeError(f\"Module '{module_name}' does not define CONFIGS.\")\n",
    "\n",
    "    CONFIGS = getattr(mod, \"CONFIGS\")\n",
    "    if config_name not in CONFIGS:\n",
    "        available = \", \".join(sorted(CONFIGS.keys()))\n",
    "        raise KeyError(f\"Config '{config_name}' not found in {module_name}. Available: {available}\")\n",
    "\n",
    "    return dict(CONFIGS[config_name])  # copy so we can tweak\n",
    "\n",
    "cfg_dict = load_named_config(\"model_configs\", arch)\n",
    "\n",
    "\n",
    "# ------------------- Model Configuration -------------------\n",
    "\n",
    "# Build HookedTransformerConfig using the loaded config\n",
    "cfg = HookedTransformerConfig(\n",
    "    n_layers=cfg_dict[\"n_layers\"],\n",
    "    d_model=cfg_dict[\"d_model\"],\n",
    "    n_heads=cfg_dict[\"n_heads\"],\n",
    "    d_head=cfg_dict[\"d_head\"],\n",
    "    d_mlp=cfg_dict.get(\"d_mlp\", None),\n",
    "    n_ctx=cfg_dict[\"n_ctx\"],\n",
    "    act_fn=cfg_dict.get(\"act_fn\", \"gelu\"),\n",
    "    d_vocab=cfg_dict[\"d_vocab\"],\n",
    "    init_weights=True,\n",
    "    tokenizer_name=cfg_dict[\"tokenizer_name\"],\n",
    "    model_name=cfg_dict.get(\"model_name\", arch),\n",
    "    attn_only=cfg_dict.get(\"attn_only\", False),\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "88a89e49",
   "metadata": {},
   "source": [
    "## Prompt Sentences Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "4c341060",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loaded 100 prompts from ./100_prompts.pkl\n"
     ]
    }
   ],
   "source": [
    "import pickle\n",
    "\n",
    "prompts_file = \"100_prompts\"\n",
    "\n",
    "with open(f\"./{prompts_file}.pkl\", \"rb\") as f:\n",
    "    prompts = pickle.load(f)\n",
    "\n",
    "print(f\"Loaded {len(prompts)} prompts from ./{prompts_file}.pkl\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e273fe78",
   "metadata": {},
   "source": [
    "## Stability comparison: Adam vs AdamW"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c1b14271",
   "metadata": {},
   "outputs": [],
   "source": [
    " \n",
    "# Setting device to CPU as GPU memory is insufficient for this computation, but for smaller number of prompts/models it can be set to GPU\n",
    "device = 'cpu'\n",
    "\n",
    "# Run for each arch but only for the single mentioned epoch (first entry of epoch_list).\n",
    "# Then plot all arch curves on the same plot.\n",
    "arch_list = [f\"{arch}\", f\"{arch}_wd\"]\n",
    "\n",
    "# constants\n",
    "SEEDS = [i for i in range(1,51)]\n",
    "if \"gpt2\" in arch:\n",
    "    SEEDS = [i for i in range(1,6)]\n",
    "SCRATCH = \"Path to root directory\"\n",
    "chkpt_file = \"final.pt\"\n",
    "shard = 9\n",
    "epoch = 1\n",
    "\n",
    "# Constants\n",
    "NUM_LAYERS = cfg.n_layers\n",
    "NUM_HEADS = cfg.n_heads\n",
    "ATTN_ONLY = cfg.attn_only\n",
    "\n",
    "# Define function to extract lower triangular part of attention matrix\n",
    "def lower_triang(mat):\n",
    "    lower_triangular_mat = torch.tril(mat)\n",
    "    mask = torch.tril(torch.ones_like(mat, device=device)).bool()\n",
    "    lower_triangular_vec = lower_triangular_mat[mask]\n",
    "    return lower_triangular_vec\n",
    "\n",
    "# Initialize cosine similarity module\n",
    "cos = t.nn.CosineSimilarity(dim=1, eps=1e-08)\n",
    "\n",
    "# storage across architectures for combined plotting\n",
    "arch_layer_means = {}\n",
    "arch_layer_vars = {}\n",
    "\n",
    "for arch in arch_list:\n",
    "    print(f\"Processing arch {arch} (epoch {epoch}) ...\")\n",
    "\n",
    "    # Models weights directory\n",
    "    chkpt_dir = SCRATCH + \"chkpts/\" + arch\n",
    "    print(f\"chkpt_dir: {chkpt_dir}/{arch}\")\n",
    "\n",
    "    print(f\"Processing arch: {arch}\")\n",
    "    cfg_dict = load_named_config(\"model_configs\", arch)\n",
    "\n",
    "    # Build HookedTransformerConfig for this arch\n",
    "    cfg = HookedTransformerConfig(\n",
    "        n_layers=cfg_dict[\"n_layers\"],\n",
    "        d_model=cfg_dict[\"d_model\"],\n",
    "        n_heads=cfg_dict[\"n_heads\"],\n",
    "        d_head=cfg_dict[\"d_head\"],\n",
    "        d_mlp=cfg_dict.get(\"d_mlp\", None),\n",
    "        n_ctx=cfg_dict[\"n_ctx\"],\n",
    "        act_fn=cfg_dict.get(\"act_fn\", \"gelu\"),\n",
    "        d_vocab=cfg_dict[\"d_vocab\"],\n",
    "        init_weights=True,\n",
    "        tokenizer_name=cfg_dict[\"tokenizer_name\"],\n",
    "        model_name=cfg_dict.get(\"model_name\", arch),\n",
    "        attn_only=cfg_dict.get(\"attn_only\", False),\n",
    "    )\n",
    "\n",
    "    # Load models for this epoch\n",
    "    models = []\n",
    "    for SEED in SEEDS:\n",
    "        cfg.seed = SEED\n",
    "        cfg.init_weights = True\n",
    "        model = HookedTransformer(cfg)\n",
    "        models.append(model)\n",
    "\n",
    "    for ind, SEED in enumerate(SEEDS):\n",
    "        if (arch == \"gpt2\") or (arch == \"gpt2_wd\"):\n",
    "            model_state_dict = t.load(chkpt_dir + f\"/gpt2_seed{SEED}_shard{shard}_epoch{epoch}_owt/{chkpt_file}\")\n",
    "            models[ind].load_and_process_state_dict(model_state_dict, fold_ln=False)\n",
    "        else:\n",
    "            if ATTN_ONLY:\n",
    "                model_state_dict = t.load(\n",
    "                    chkpt_dir + f\"/causal_attn_only_l{NUM_LAYERS}_h{NUM_HEADS}_seed{SEED}_epoch{epoch}_c4_gelu/{chkpt_file}\"\n",
    "                )\n",
    "                models[ind].load_and_process_state_dict(model_state_dict, fold_ln=False)\n",
    "\n",
    "            else:\n",
    "                model_state_dict = t.load(\n",
    "                    chkpt_dir + f\"/causal_attn_l{NUM_LAYERS}_h{NUM_HEADS}_seed{SEED}_epoch{epoch}_c4_gelu/{chkpt_file}\"\n",
    "                )\n",
    "                models[ind].load_and_process_state_dict(model_state_dict, fold_ln=False)\n",
    "\n",
    "\n",
    "    # run prompts to collect caches (using CPU to avoid CUDA OOM)\n",
    "    prompts_cache = []\n",
    "    for prompt in prompts:\n",
    "        cache_for_prompt = []\n",
    "        for ind in range(len(SEEDS)):\n",
    "            _, cache_i = models[ind].run_with_cache(prompt, remove_batch_dim=True)\n",
    "            # Keep cache on CPU\n",
    "            cache_i = cache_i.to('cpu')\n",
    "            cache_for_prompt.append(cache_i)\n",
    "        prompts_cache.append(cache_for_prompt)\n",
    "\n",
    "    # Constants\n",
    "    NUM_MODELS = len(models)\n",
    "    NUM_HEADS = models[0].cfg.n_heads\n",
    "    NUM_LAYERS = models[0].cfg.n_layers\n",
    "    NUM_PROMPTS = len(prompts_cache)\n",
    "    \n",
    "    \n",
    "    # Free memory held by models\n",
    "    del models\n",
    "    del model_state_dict\n",
    "    torch.cuda.empty_cache()\n",
    "    \n",
    "    print(\"Computing cosine similarity matrix...\")\n",
    "    prompts_cs_matrix = t.empty(( NUM_LAYERS, NUM_HEADS, NUM_MODELS, NUM_HEADS, NUM_PROMPTS), device=device)\n",
    "\n",
    "    # Setting Anchor seed/refit\n",
    "    anchor = 0\n",
    "\n",
    "    # Compute cosine-similarity matrix across layers/heads/models per prompt\n",
    "    for ind_prompt in range(NUM_PROMPTS):\n",
    "        cache = prompts_cache[ind_prompt]\n",
    "        cache_anchor = cache[anchor].to(device)\n",
    "        \n",
    "        for layer in range(NUM_LAYERS):\n",
    "            for head_anchor in range(NUM_HEADS):\n",
    "                    \n",
    "                    head_anchor_attn = cache_anchor[utils.get_act_name('pattern',layer,'a')][head_anchor]\n",
    "                    head_anchor_attn = lower_triang(head_anchor_attn.to(device))\n",
    "                    head_anchor_attn = t.unsqueeze(head_anchor_attn, 0)\n",
    "\n",
    "                    for model_i in range(NUM_MODELS):\n",
    "                        cache_model_i = cache[model_i].to(device)\n",
    "                        for head_pair in range(NUM_HEADS):\n",
    "                            head_i_attn = cache_model_i[utils.get_act_name('pattern',layer,'a')][head_pair]\n",
    "                            head_i_attn = lower_triang(head_i_attn.to(device))\n",
    "                            head_i_attn = t.unsqueeze(head_i_attn, 0)\n",
    "                            cos_score_i = cos(head_anchor_attn, head_i_attn)\n",
    "                            prompts_cs_matrix[layer, head_anchor, model_i, head_pair, ind_prompt] = cos_score_i\n",
    "                            del head_i_attn, cos_score_i\n",
    "\n",
    "                        del cache_model_i\n",
    "\n",
    "                    del head_anchor_attn\n",
    "\n",
    "        del cache_anchor\n",
    "        torch.cuda.empty_cache()\n",
    "\n",
    "    # Get best-matching head & Aggregate to get per-(layer, head_anchor)\n",
    "    results = []\n",
    "    for layer_i in range(NUM_LAYERS):\n",
    "        csh = prompts_cs_matrix[layer_i,:,:,:]                # [head_anchor, model_i, head_pair, prompts]\n",
    "        csh = torch.mean(csh, -1)                            # mean over prompts -> [head_anchor, model_i, head_pair]\n",
    "        csh = csh.max(dim=-1, keepdim=True)                  # max over head_pair -> values shape [head_anchor, model_i, 1]\n",
    "        csh = csh.values[:,:,0]                              # [head_anchor, model_i]\n",
    "        csh = torch.cat([csh[:, :anchor], csh[:, anchor+1:]], dim=1) # remove comparison of anchor model with itself\n",
    "        csh = csh.mean(dim=-1).reshape(NUM_HEADS, 1)         # mean over models -> [head_anchor, 1]\n",
    "\n",
    "        # store results\n",
    "        for head_anchor in range(NUM_HEADS):\n",
    "            results.append({\n",
    "                \"layer\": layer_i + 1,\n",
    "                \"head_anchor\": head_anchor + 1,\n",
    "                \"cos_sim\": csh[head_anchor].item()\n",
    "            })\n",
    "\n",
    "    df_layer_sim = pd.DataFrame(results)\n",
    "\n",
    "    # collect per-layer mean & var\n",
    "    layer_means = []\n",
    "    layer_vars = []\n",
    "    ticklabel_layers = [i for i in range(1, NUM_LAYERS+1)]\n",
    "    for layer in ticklabel_layers:\n",
    "        layer_df = df_layer_sim[df_layer_sim['layer'] == layer]\n",
    "        layer_means.append(layer_df['cos_sim'].mean())\n",
    "        layer_vars.append(layer_df['cos_sim'].var())\n",
    "\n",
    "    arch_layer_means[arch] = layer_means\n",
    "    arch_layer_vars[arch] = layer_vars\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "d5da3bdc",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA2oAAAGQCAYAAADfvZNdAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8hTgPZAAAACXBIWXMAAA9hAAAPYQGoP6dpAACWSUlEQVR4nOzdeVzU1f7H8dewg6wuCAgqau477mZptmilLWq2uNRNbb+3W7d7695bab+63botd2230jJNzUrLNDUtdxP3fQMFFBUQGHaYmd8fXxlBQEGWmYH38/GYR8z3e+b7PSOkvOec8zkmm81mQ0RERERERJyGm6M7ICIiIiIiIqUpqImIiIiIiDgZBTUREREREREno6AmIiIiIiLiZBTUREREREREnIyCmoiIiIiIiJNRUBMREREREXEyCmoiIiIiIiJORkFNRERERETEySioiYiIiIiIOBmXCWo5OTn88MMPvPzyy9x55520atUKk8mEyWRi+vTpNXKP06dP8/TTT9OhQwd8fX1p3LgxQ4YM4aOPPsJms9XIPURERERERC7Hw9EdqKwtW7Zw880319r1Y2Njuemmm0hNTQXA398fs9nMunXrWLduHQsXLmTx4sV4eXnVWh9ERERERETAhUbUAEJCQhg+fDjPPPMMc+fOJSwsrEaum5GRwa233kpqaiodO3bk119/xWw2k52dzX//+188PT1Zvnw5Tz75ZI3cT0RERERE5FJcZkRtyJAhpKWllTr27LPP1si133jjDZKTk/H19WXp0qVER0cD4OXlxWOPPUZmZiZ//vOf+eCDD3jyySdp3759jdxXRERERESkPC4zoubu7l5r1549ezYAd999tz2klfTEE0/g7++PxWJhzpw5tdYPERERERERcKGgVlsOHjzIiRMnABg5cmS5bfz9/RkyZAgAP/74Y531TUREREREGqYGH9T27Nlj/7pr164Vtis+t2/fvlrvk4iIiIiINGwus0attpw8edL+dYsWLSpsV3wuMzOTrKws/P39y22Xn59Pfn6+/bnVaiUtLY0mTZpgMplqqNciIiIiIuJqbDYbZrOZiIgI3NwuPWbW4IOa2Wy2f+3n51dhu5LnzGZzhUHt1VdfZcaMGTXXQRERERERqVcSEhKIjIy8ZJsGH9Rq2nPPPcdTTz1lf56RkUHLli1JSEggMDDQgT0TERERERFH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a+4NiYiIiIiIVMBlgtqsWbPYvXs3AF999RXXX389YJT6Hj9+PO+//z4AS5cuZdWqVQ7rp4iIiIiISHW5VFADGDZsGAMHDixz/u677yY6OhqA2bNn12nfREREREREapJLBLWcnBzWr18PwMiRI8ttYzKZGDFiBAA//vhjnfVNRERERESkprlEUNu/fz9WqxWArl27Vtiu+FxycjJpaWlVvs/evXvp2rUrfn5++Pv706FDB6ZOncr27duvrOMiIiIiIiJXwCXKGJ48edL+dYsWLSpsV/LcyZMnL1nBsTwpKSmkpaURHBxMZmYmhw4d4tChQ8ycOZM///nPvPzyy5e9Rn5+Pvn5+fbnGRkZAGRmZlapLyIiIiIiUr8UZwKbzXbZti4R1Mxms/1rPz+/CtuVPFfyNZdz1VVX8frrr3PbbbcRHR2Np6cnBQUFrFmzhj//+c/ExsbyyiuvEBISwtNPP33Ja7366qvMmDGjzPGoqKhK90dEREREROovs9lMUFDQJduYbJWJcw72xRdfcN999wFw+PBh2rVrV267FStWcOONNwKwYcOGcouOVFVeXh7XXHMNv/76K/7+/iQmJl7yD/XiETWr1UpaWhpNmjTBZDJVuz/VkZmZSVRUFAkJCQQGBjq0L2LQ98T56HviXPT9cD76njgffU+ci74fzseZvic2mw2z2UxERARubpdeheYSI2oBAQH2r3NycipsV/JcyddUh4+PD3/729+44YYbyMrKYtWqVdx5550Vtvf29sbb27vUseDg4BrpS00JDAx0+A+plKbvifPR98S56PvhfPQ9cT76njgXfT+cj7N8Ty43klbMJYqJRERE2L9OSkqqsF3JcyVfU10lR+aOHTtWY9cVEREREREpj0sEtU6dOtmHBvfs2VNhu+JzYWFhVS4kIiIiIiIi4ixcIqj5+fkxePBgAJYtW1ZuG5vNxvLlywHs69RqyqZNm+xfF2+q7Yq8vb158cUXy0zNFMfR98T56HviXPT9cD76njgffU+ci74fzsdVvycuUUwEYObMmUyZMgWTycTGjRvp379/qfPz589n/PjxAKxcuZLhw4dX6ro2m+2SRT7y8/O59tpr2bx5M40aNSIxMdHp1pyJiIiIiEj94hIjagCTJ0+mW7du2Gw2xowZw6pVqwCjquKCBQuYOnUqACNHjiwT0qZPn47JZMJkMhEfH1/q3C+//ML111/PZ599RmJiov14YWEhq1atYsiQIWzevBmAF154QSFNRERERERqnUtUfQTw8PBg8eLFDBs2jPj4eK6//nr8/PywWq3k5eUB0KtXL+bMmVOl69psNlatWmUPfr6+vjRq1IiMjAwKCwsBcHNz49lnn+WPf/xjzb4pERERERGRcrhMUANo3bo1u3bt4o033mDRokXExcXh6elJly5duOeee3jiiSfw8vKq0jW7devGG2+8wcaNG9m9ezcpKSmkp6fj5+dH586dGTJkCNOmTaNbt2619K5ERERERERKc5k1aiIiIiIiIg2Fy6xRk6rLycnhhx9+4OWXX+bOO++kVatW9rV606dPd3T3GqTU1FQ++eQTJkyYQOfOnWnUqBHe3t5ERkZy++238/XXXzu6iw3Otm3bmDFjBqNHj6Zjx440adIET09PmjRpwuDBg3nllVdIS0tzdDcbvL///e/2v78uVQBKat6nn35a6s++osfKlSsd3dUGJzMzk9dee41BgwbRrFkz+78nw4YNY/r06aSnpzu6i/VeZf7fKH4MGzbM0d1tcFasWMFdd91Fq1at8PHxwdfXlzZt2nDffffx888/O7p7l+VSUx+larZs2cLNN9/s6G5ICWFhYRQVFdmf+/j44OnpSVJSEklJSXz77beMHDmShQsX4ufn58CeNhwff/wx//vf/+zPi/8iT0tLY8OGDWzYsIF//vOfLF68mIEDBzqwpw3XwYMHmTFjhqO70eC5ubnRrFmzCs+7WtlrV7d69WruueceTp8+DYCXlxd+fn72f0/WrFnD7bffTs+ePR3b0XquefPmlzxfWFho/7Cvb9++ddElwahB8cgjj/D+++/bj/n6+gIQFxdHXFwcX3zxBb///e956623HNXNy9KIWj0XEhLC8OHDeeaZZ5g7dy5hYWGO7lKDVlRURL9+/XjnnXc4evQoubm5ZGVlERcXx4MPPgjADz/8wEMPPeTgnjYc/fr14x//+AcbN27k3Llz5ObmkpmZidlsZtasWTRr1oyUlBRuv/12MjIyHN3dBsdqtfKb3/yGvLw8BWUHi4qKIjk5ucLHkCFDHN3FBmP9+vXccsstnD59mjvvvJNff/2VvLw8zp07R3Z2Nlu2bOEvf/kLQUFBju5qvXep/yeSk5P585//bG9b/O+81L5PP/3UHtLGjh3LoUOH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KCkpYcGCBYwePZrevXvTvn17XC4XMTEx3H777axfvz7gcVdccQUOh4P77ruv0fPn5eXhcDhwOp0UFhbW2753715SU1O58MILiYiIICwsjPj4eB544AE8Hk/Ac7799ts4HA66desGQH5+PiNHjuTss88mJCSEcePG/aXnQERErKFCTUREpAEvvvgiEyZMICcnhx07dpjrPR4P77//Pv379+ell16qd9y9994LwJIlS6ioqGjw/FlZWQAkJSXRvXt3v21LliwhPj6eF198ke+//57ff/8dgB9//JGXXnqJiy66iJUrVzaZ/9prr2XZsmV4vV5CQkJO7QcXERHLqVATERFpQOfOncnIyGDTpk1UVFRw5MgRvF4vhYWFPPDAAwA89NBDfPvtt37H3XrrrbRr147jx4/z4YcfBjx3cXExubm5ANxzzz1+27788kvGjBlDTU0N06dPZ8+ePXi9XsrLy/nhhx8YNWoUpaWljBo1qsGRtaKiIqZNm8bYsWPxeDwcPXoUr9fL448//k+fFhERaQEq1ERERBowadIkMjMz6du3L6GhoQA4HA5iY2OZO3cu9913HzU1Nbz66qt+x7ndbsaOHQvAvHnzAp77nXfeoaqqiujoaIYPH26u9/l8TJkyBZ/Px6uvvspzzz1Ht27dzFsL9OrVi+zsbIYPH87x48eZPXt2wPOfOHGCESNGsHDhQrp27QpASEgIPXr0+MfPi4iIND8VaiIiIn/T9ddfD8DatWvrbaub/rh+/Xq2bdtWb/v8+fMBSElJoXXr1ub61atX89NPPxEVFcWECRMa/L/HjBkDwBdffNHgPo888sgp/BQiImJHrawOICIiYmeFhYW89tpr5Ofns3v3bkpLS/H5fH77/Pzzz/WO69WrF4mJieTn55OVleV3LduaNWv44YcfcDgcTJw40e+4devWAXDs2DE6d+7cYK6qqioA9u3bF3C72+3m0ksvPbUfUkREbEeFmoiISANyc3NJTk6msrLSXNe2bVtcLhcOh4OqqipKSkooLy8PePy9995Lfn4+ixcvZubMmbhcLuCP6ZCDBw8mNjbW75hff/0VgOrqaoqKiprM6PV6A67v0KEDTqcmzoiI/FfpHVxERCSAw4cPM27cOCorK7nmmmsoKCigoqKCY8eOUVRUxIEDB8jJyWn0HDfeeCPR0dGUlJSQnZ0N1Lb8/+ijj4Daa+D+rKamBoDLL78cwzBO6RGIOjyKiPy3qVATEREJYPny5Rw/fpx27drx6aefcvXVV+N2u/32OXDgQKPnaN26NXfffTfwRyv+xYsXc+LECTp16uTXRKROp06dgIanNIqISHBQoSYiIhLA/v37gdprzcLCwgLus2rVqibPM2nSJJxOJ2vXrmXHjh1mwTZ+/Hi/JiJ1BgwYANQWgZs2bfq78UVE5D9OhZqIiEgAZ5xxBgA7d+7kxIkT9bZv2bKF9957r8nzxMTEcN111wG116xt27YtYBOROomJicTFxQHw4IMPmk1DGnLkyJEmM4iIyH+PCjUREQk6xcXFjT6OHj3KkCFDcDqdHDlyhDvuuINffvkFqO22mJ2dzZAhQ4iMjDyl/6+uVf/q1auBwE1E6rRq1Yo33niDVq1asXbtWq666iry8vKorq429yksLOSNN97gsssu47XXXvsnT4WIiNiUCjUREQk6Z511VqOPQYMG0bNnT9LT0wH4+OOPOeecczjzzDOJiIjg1ltvJSIiwq/lfmOGDh1KTEyM+e9ATUROdu2115KTk0NkZCQbNmwgKSmJ8PBwoqKicLlc9OjRg8mTJ7Np0yYcDsfffyJERMS2VKiJiIg0YMaMGbz77rskJCTgdruprq4mLi6ORx99lG+//bbR+5ydzOl0ctNNNwE02ETkz0aOHMmuXbvIyMggISGBiIgIjh49Sps2bejTpw8TJkwgNzfXLCZFROT04jAa6usrIiIi/5revXuzfft2HnnkEZ555hmr44iIiM2pUBMREWlmBQUFJCYm4nQ62b17N926dbM6koiI2JymPoqIiDSjoqIiUlNTAbjllltUpImIyCnRiJqIiEgzuO2221i3bh0HDhzg999/JzIykq1btzbY7VFERORkGlETERFpBgcOHODnn38mPDycpKQkCgoKVKSJiMgp04iaiIiIiIiIzWhETURERERExGZUqImIiIiIiNiMCjURERERERGbUaEmIiIiIiJiMyrUREREREREbEaFmoiIiIiIiM2oUBMREREREbEZFWoiIiIiIiI28z9RRmsUiLdRxAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 1000x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Combined plots: all architectures on same axes for the selected epoch\n",
    "plt.figure(figsize=(10,4))\n",
    "for arch in arch_list:\n",
    "    plt.plot(ticklabel_layers, arch_layer_means[arch], marker='o', label='Adam' if arch == arch_list[0] else 'AdamW')\n",
    "plt.xlabel('Layer', fontsize=18)\n",
    "plt.ylabel('Stability', fontsize=18)\n",
    "#plt.title(f'Stability comparison for 8-layers 8-heads MLP architecture: Adam vs AdamW')\n",
    "plt.ylim(0.5,1)\n",
    "plt.xticks(fontsize=18)\n",
    "plt.yticks(fontsize=18)\n",
    "plt.legend(fontsize=18)\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c767178b",
   "metadata": {},
   "source": [
    "## Adam vs AdamW - Mechanistic check"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6c5b6255",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Notebook cell: mean L2 norms of attn_out and resid_mid (with robust fallbacks)\n",
    "\n",
    "import torch as t\n",
    "import pandas as pd\n",
    "from typing import List, Optional\n",
    "\n",
    "def _pick_hook_template(model, candidates: List[str], layer0_prefix=\"blocks.0\"):\n",
    "    \"\"\"\n",
    "    Given candidate hook names for layer 0, return a template 'blocks.{l}.<hook>'\n",
    "    for the first one found in cache.\n",
    "    \"\"\"\n",
    "    test_tokens = model.to_tokens(\"test\", prepend_bos=True)\n",
    "    with t.no_grad():\n",
    "        _, cache = model.run_with_cache(test_tokens, return_type=None)\n",
    "\n",
    "    for name in candidates:\n",
    "        if name in cache:\n",
    "            del cache\n",
    "            return name.replace(layer0_prefix, \"blocks.{l}\")\n",
    "\n",
    "    del cache\n",
    "    raise ValueError(\n",
    "        \"None of the candidate hooks were found. \"\n",
    "        \"Inspect cache.keys() to see available hook names.\"\n",
    "    )\n",
    "\n",
    "def _pick_attn_out_template(model) -> str:\n",
    "    # Stable order: true attn output -> attn result (if enabled) -> z (pre-W_O)\n",
    "    candidates = [\n",
    "        \"blocks.0.hook_attn_out\",      # most stable \"attn_out\"\n",
    "        \"blocks.0.attn.hook_result\",   # only if cfg.use_attn_result=True\n",
    "        \"blocks.0.attn.hook_z\",        # fallback (pre W_O)\n",
    "    ]\n",
    "    return _pick_hook_template(model, candidates)\n",
    "\n",
    "def _pick_resid_after_attn_template(model) -> str:\n",
    "    # Prefer resid_mid (between attn and mlp). If absent, use resid_post (after attn),\n",
    "    # common in attn-only models. Last resort resid_pre.\n",
    "    candidates = [\n",
    "        \"blocks.0.hook_resid_mid\",\n",
    "        \"blocks.0.hook_resid_post\",\n",
    "        \"blocks.0.hook_resid_pre\",\n",
    "    ]\n",
    "    return _pick_hook_template(model, candidates)\n",
    "\n",
    "def mean_l2_norms_attn_out_and_resid_mid(\n",
    "    model,\n",
    "    prompts: List[str],\n",
    "    batch_size: int = 8,\n",
    "    prepend_bos: bool = True,\n",
    "    device: Optional[str] = None,\n",
    ") -> pd.DataFrame:\n",
    "    \"\"\"\n",
    "    Mean per-token L2 norms, averaged over tokens+prompts (padding excluded), for:\n",
    "      - attn_out  : best available attn-out hook\n",
    "      - resid_mid : best available residual-after-attn hook (resid_mid if present)\n",
    "\n",
    "    Returns DataFrame with one row per layer.\n",
    "    \"\"\"\n",
    "    model.eval()\n",
    "    if device is None:\n",
    "        device = \"cuda\" if t.cuda.is_available() else \"cpu\"\n",
    "    model = model.to(device)\n",
    "\n",
    "    tokenizer = model.tokenizer\n",
    "    n_layers = model.cfg.n_layers\n",
    "\n",
    "    attn_template  = _pick_attn_out_template(model)\n",
    "    resid_template = _pick_resid_after_attn_template(model)\n",
    "\n",
    "    attn_sums  = t.zeros(n_layers, dtype=t.float64)\n",
    "    resid_sums = t.zeros(n_layers, dtype=t.float64)\n",
    "    total_tokens = 0.0\n",
    "\n",
    "    bos_id = getattr(tokenizer, \"bos_token_id\", None)\n",
    "\n",
    "    # Build hook names for filtering once\n",
    "    hook_names = []\n",
    "    for l in range(n_layers):\n",
    "        hook_names.append(attn_template.format(l=l))\n",
    "        hook_names.append(resid_template.format(l=l))\n",
    "\n",
    "    for start in range(0, len(prompts), batch_size):\n",
    "        batch_prompts = prompts[start:start + batch_size]\n",
    "\n",
    "        enc = tokenizer(\n",
    "            batch_prompts,\n",
    "            return_tensors=\"pt\",\n",
    "            padding=True,\n",
    "            truncation=True,\n",
    "            add_special_tokens=True,\n",
    "        )\n",
    "        tokens = enc[\"input_ids\"]\n",
    "        mask   = enc[\"attention_mask\"]  # 1 real, 0 pad\n",
    "\n",
    "        if prepend_bos and bos_id is not None:\n",
    "            bos_col = t.full((tokens.size(0), 1), bos_id, dtype=t.long)\n",
    "            tokens = t.cat([bos_col, tokens], dim=1)\n",
    "            mask   = t.cat([t.ones((mask.size(0), 1), dtype=mask.dtype), mask], dim=1)\n",
    "\n",
    "        tokens = tokens.to(device)\n",
    "        mask   = mask.to(device).float()  # [batch, seq]\n",
    "\n",
    "        with t.no_grad():\n",
    "            _, cache = model.run_with_cache(\n",
    "                tokens,\n",
    "                return_type=None,\n",
    "                names_filter=hook_names,\n",
    "            )\n",
    "\n",
    "        batch_token_count = mask.sum().item()\n",
    "        total_tokens += batch_token_count\n",
    "\n",
    "        for l in range(n_layers):\n",
    "            attn  = cache[attn_template.format(l=l)]     # [batch, seq, d_model] or [batch, seq, head, d_head]\n",
    "            resid = cache[resid_template.format(l=l)]    # [batch, seq, d_model]\n",
    "\n",
    "            # If attn hook is z/result with head dim, flatten last two dims\n",
    "            if attn.ndim == 4:\n",
    "                attn = attn.reshape(attn.shape[0], attn.shape[1], -1)\n",
    "\n",
    "            attn_norm  = t.linalg.norm(attn, dim=-1)     # [batch, seq]\n",
    "            resid_norm = t.linalg.norm(resid, dim=-1)    # [batch, seq]\n",
    "\n",
    "            attn_sums[l]  += (attn_norm  * mask).sum().double().cpu()\n",
    "            resid_sums[l] += (resid_norm * mask).sum().double().cpu()\n",
    "\n",
    "        del cache\n",
    "\n",
    "    attn_means  = attn_sums / total_tokens\n",
    "    resid_means = resid_sums / total_tokens\n",
    "\n",
    "    return pd.DataFrame({\n",
    "        \"layer\": list(range(n_layers)),\n",
    "        \"attn_out_hook_used\":  [attn_template] * n_layers,\n",
    "        \"resid_hook_used\":     [resid_template] * n_layers,\n",
    "        \"attn_out_mean_l2\":    attn_means.numpy(),\n",
    "        \"resid_mid_mean_l2\":   resid_means.numpy(),\n",
    "    })\n",
    "\n",
    "\n",
    "# Run for each arch but only for the single mentioned epoch (first entry of epoch_list).\n",
    "# Then plot all arch curves on the same plot.\n",
    "arch = arch_list[0]\n",
    "epoch_list = [1, 2]\n",
    "arch_list = [f\"{arch}\", f\"{arch}_wd\"]\n",
    "\n",
    "# pick only the mentioned epoch (first one). Change this if you want a different single epoch.\n",
    "epoch_to_run = epoch_list[0]\n",
    "\n",
    "ylim_max = 150\n",
    "\n",
    "# Setting Anchor seed/refit\n",
    "anchor = 1\n",
    "SEEDS = [anchor]\n",
    "SCRATCH = \"Path to root directory\"\n",
    "shard_file = \"final.pt\"\n",
    "\n",
    "# helper (kept from original)\n",
    "def lower_triang(mat):\n",
    "    lower_triangular_mat = torch.tril(mat)\n",
    "    mask = torch.tril(torch.ones_like(mat, device=device)).bool()\n",
    "    lower_triangular_vec = lower_triangular_mat[mask]\n",
    "    return lower_triangular_vec\n",
    "\n",
    "cos = t.nn.CosineSimilarity(dim=1, eps=1e-08)\n",
    "\n",
    "# storage across architectures for combined plotting\n",
    "arch_layer_means = {}\n",
    "arch_layer_vars = {}\n",
    "\n",
    "for arch in arch_list:\n",
    "    print(f\"Processing arch {arch} (epoch {epoch_to_run}) ...\")\n",
    "\n",
    "    # Load models for this epoch\n",
    "    models = []\n",
    "    for SEED in SEEDS:\n",
    "        cfg.seed = SEED\n",
    "        cfg.init_weights = True\n",
    "        model = HookedTransformer(cfg)\n",
    "        models.append(model)\n",
    "\n",
    "    for ind, SEED in enumerate(SEEDS):\n",
    "        model_state_dict = t.load(\n",
    "            SCRATCH + f\"chkpts/{arch}/causal_attn_l8_h8_seed{SEED}_epoch{epoch_to_run}_c4_gelu/{shard_file}\"\n",
    "        )\n",
    "       \n",
    "        models[ind].load_and_process_state_dict(model_state_dict, fold_ln=False)\n",
    "\n",
    "   \n",
    "    model = models[0]\n",
    "    df_norms = mean_l2_norms_attn_out_and_resid_mid(model, prompts, batch_size=4)\n",
    "\n",
    "    # Plot attn_out_mean_l2 and resid_mid_mean_l2 for all layers\n",
    "    plt.figure(figsize=(8,4))\n",
    "    x = df_norms['layer'] + 1  # convert 0-based layer indices to 1-based for display\n",
    "    plt.plot(x, df_norms['attn_out_mean_l2'], marker='o', label='attn_out_mean_l2')\n",
    "    plt.plot(x, df_norms['resid_mid_mean_l2'], marker='o', label='resid_mid_mean_l2')\n",
    "    plt.xticks(x)\n",
    "    plt.xlabel('Layer')\n",
    "    plt.ylabel('Mean L2 norm')\n",
    "    plt.ylim(0, ylim_max)\n",
    "    plt.legend()\n",
    "    plt.show()\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9a7598d4",
   "metadata": {},
   "outputs": [],
   "source": [
    "# storage across architectures for combined plotting\n",
    "arch_layer_means = {}\n",
    "arch_layer_vars = {}\n",
    "\n",
    "# prepare a single figure for all architectures\n",
    "plt.figure(figsize=(10,5))\n",
    "\n",
    "for arch in arch_list:\n",
    "    print(f\"Processing arch {arch} (epoch {epoch_to_run}) ...\")\n",
    "\n",
    "    # Load models for this epoch\n",
    "    models = []\n",
    "    for SEED in SEEDS:\n",
    "        cfg.seed = SEED\n",
    "        cfg.init_weights = True\n",
    "        model = HookedTransformer(cfg)\n",
    "        models.append(model)\n",
    "\n",
    "    for ind, SEED in enumerate(SEEDS):\n",
    "        model_state_dict = t.load(\n",
    "            SCRATCH + f\"chkpts/{arch}/causal_attn_l8_h8_seed{SEED}_epoch{epoch_to_run}_c4_gelu/{shard_file}\"\n",
    "        )\n",
    "        models[ind].load_and_process_state_dict(model_state_dict, fold_ln=False)\n",
    "\n",
    "    model = models[0]\n",
    "    df_norms = mean_l2_norms_attn_out_and_resid_mid(model, prompts, batch_size=4)\n",
    "\n",
    "    \n",
    "    x = df_norms['layer'] + 1  # convert 0-based layer indices to 1-based for display\n",
    "\n",
    "    colors = ['#1f77b4', '#ff7f0e']  # matplotlib default blue and orange\n",
    "\n",
    "    if \"_wd\" in arch:\n",
    "        arch_label = \"AdamW\"\n",
    "        plt.plot(x, df_norms['attn_out_mean_l2'], marker='o', color=colors[0], label=f'Attention output norm ({arch_label})')\n",
    "        plt.plot(x, df_norms['resid_mid_mean_l2'], marker='s', color=colors[1], label=f'Residual stream norm ({arch_label})')\n",
    "    else:\n",
    "        arch_label = \"Adam\"\n",
    "        plt.plot(x, df_norms['attn_out_mean_l2'], marker='o', linestyle='--', color=colors[0], label=f'Attention output norm ({arch_label})')\n",
    "        plt.plot(x, df_norms['resid_mid_mean_l2'], marker='s', linestyle='--', color=colors[1], label=f'Residual stream norm ({arch_label})')\n",
    "# finalize single combined plot\n",
    "plt.xticks(x)\n",
    "plt.xlabel('Layer', fontsize=18)\n",
    "plt.ylabel('Mean L2 norm', fontsize=18)\n",
    "#plt.title(f'Activations L2 norm: Attention output vs Residual stream, Architecture: L8 H8 MLP')\n",
    "plt.ylim(0, ylim_max)\n",
    "plt.xticks(fontsize=18)\n",
    "plt.yticks(fontsize=18)\n",
    "plt.legend(fontsize=12)\n",
    "plt.show()\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "py3.10.4",
   "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.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
