{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# TokFSM Tutorial\n",
    "\n",
    "This tutorial focuses on studying codebook models trained on an algorithmic sequence modeling dataset called TokFSM. The purpose of this dataset is to create a controlled setting exhibiting many of the complexities of language\n",
    "modeling, but where the latent features present in the sequence are known. This enables us to\n",
    "evaluate how well the model learns codes that activate on these distinct features.\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Setup"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import plotly.express as px\n",
    "import torch\n",
    "import transformers\n",
    "import numpy as np\n",
    "import itertools\n",
    "from codebook_features import models, run_clm, train_fsm_model, trainer as cb_trainer\n",
    "from codebook_features import fsm_utils, utils as cb_utils\n",
    "import os\n",
    "import plotly.graph_objects as go\n",
    "from functorch.dim import dims\n",
    "\n",
    "# We turn automatic differentiation off, to save GPU memory,\n",
    "# as this tutorial focuses only on model inference\n",
    "torch.set_grad_enabled(False)\n",
    "model_id = \"TokFSM_k1_codebook_model\""
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "The TokFSM dataset is produced by first constructing a simplified finite state machine (FSM). Our FSM is defined by $(V, E)$ where $V = \\{0...N-1\\}$ is a set of nodes and $E \\subseteq V \\times V$ contains the probability that one state will transition to the next state in each iteration. In our setting, we choose $N=100$ and give each node 10 randomly chosen outbound neighbors, each of which is assigned an equal transition probability ($0.1$).\n",
    "\n",
    "Here we specify the codebook model hyperparameters and the FSM parameters and load the FSM object."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Hyperparameters\n",
    "hp = dict(\n",
    "    run_name=\"hooked_model_neox\",\n",
    "    tags=[],\n",
    "    num_states=100,\n",
    "    num_edges=10,\n",
    "    seq_len=128,\n",
    "    vocab_size=11,\n",
    "    hidden_size=128,\n",
    "    intermediate_size=512,\n",
    "    num_hidden_layers=4,\n",
    "    num_attention_heads=4,\n",
    "    rotary_emb_base=10000,\n",
    ")\n",
    "\n",
    "device = \"cpu\"\n",
    "config = transformers.GPTNeoXConfig(\n",
    "    vocab_size=hp[\"vocab_size\"],\n",
    "    hidden_size=hp[\"hidden_size\"],\n",
    "    num_hidden_layers=hp[\"num_hidden_layers\"],\n",
    "    num_attention_heads=hp[\"num_attention_heads\"],\n",
    "    intermediate_size=hp[\"intermediate_size\"],\n",
    "    rotary_emb_base=hp[\"rotary_emb_base\"],\n",
    "    bos_token_id=hp[\"vocab_size\"] - 1,\n",
    "    eos_token_id=hp[\"vocab_size\"] - 1,\n",
    "    max_position_embeddings=hp[\"seq_len\"],\n",
    ")\n",
    "config.architectures = [\"GPTNeoXForCausalLM\"]\n",
    "model = transformers.GPTNeoXForCausalLM(config=config)\n",
    "model = model.to(device).eval()\n",
    "cb_model = models.wrap_codebook(\n",
    "    model_or_path=model,\n",
    "    pretrained_path=f\"../models/{model_id}\",\n",
    ")\n",
    "cb_model = cb_model.to(device).eval()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Convert the model into a hooked transformer model (from transformer_lens) that allows us to do code interventions easily"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "hooked_kwargs = dict(\n",
    "    center_unembed=False,\n",
    "    center_writing_weights=False,\n",
    "    fold_ln=False,\n",
    "    fold_value_biases=False,\n",
    "    refactor_factored_attn_matrices=False,\n",
    "    device=device,\n",
    ")\n",
    "hooked_model = models.convert_to_hooked_model_for_tokfsm(\n",
    "    f\"../models/{model_id}\",\n",
    "    cb_model,\n",
    "    config=config,\n",
    "    hooked_kwargs=hooked_kwargs,\n",
    ")\n",
    "hooked_model = hooked_model.to(device).eval()\n",
    "tokenizer = hooked_model.tokenizer"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Here we display an example trajectory from the FSM, both in terms of the abstract states (2-digit integers) as well as the tokens that are seen by the transformer (single digits)."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Number of states: 100\n",
      "Number of edges from every state: 10\n",
      "A random trajectory in the FSM:\n",
      "state 8 -> state 53 -> state 75 -> state 61 -> state 2\n",
      "Tokenized trajectory:\n",
      "[0, 8, 5, 3, 7, 5, 6, 1, 0, 2]\n"
     ]
    }
   ],
   "source": [
    "fsm = train_fsm_model.FSM.load(\n",
    "    f\"../models/{model_id}/fsm.npy\", representation_base=hp[\"vocab_size\"] - 1, seed=42\n",
    ")\n",
    "tokfsm = train_fsm_model.TokFSMDataset(fsm, tokenizer=tokenizer, seq_len=hp[\"seq_len\"])\n",
    "print()\n",
    "print(\"Number of states:\", fsm.N)\n",
    "print(\"Number of edges from every state:\", fsm.num_edges)\n",
    "print(\"A random trajectory in the FSM:\")\n",
    "traj = fsm.generate_trajectory(length=5)\n",
    "print(\"state \" + \" -> state \".join(map(str, traj)))\n",
    "print(\"Tokenized trajectory:\")\n",
    "print(tokenizer.encode(fsm.traj_to_str(traj)))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Load Codebook Model"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "To check that the codebook model is working, we can pass all possible states to the model and check the accuracy of the model at predicting the first state transition of the sequence."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 100/100 [00:14<00:00,  6.69it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy of the first transition: 97.50%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "acc = fsm_utils.first_transition_accuracy(hooked_model, fsm)\n",
    "print(f\"Accuracy of the first transition: {(100*acc):.2f}%\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Code Purity\n",
    "\n",
    "We want to check how many codes learned by the codebook model only activate on a single bigram or trigram. We call such codes \\\"pure\\\" codes. We can check this by passing all possible bigrams and trigrams to the codebook model and finding the fraction of codes that activated on a single bigram or trigram. (Note that this checks for purity at the first state, not throughout the entire sequence.)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100it [00:01, 60.83it/s]\n",
      "1000it [00:01, 588.40it/s]\n",
      "100it [00:01, 62.06it/s]\n",
      "1000it [00:01, 608.77it/s]\n",
      "100it [00:01, 54.67it/s]\n",
      "1000it [00:01, 600.67it/s]\n",
      "100it [00:01, 60.30it/s]\n",
      "1000it [00:01, 599.30it/s]\n"
     ]
    }
   ],
   "source": [
    "layer_purity_trigrams = []\n",
    "layer_purity_bigrams = []\n",
    "all_partitions2 = []\n",
    "all_partitions3 = []\n",
    "all_partitions_union = []\n",
    "for layer in range(hooked_model.cfg.n_layers):\n",
    "    partitions2 = fsm_utils.partition_input_space_with_codebook(\n",
    "        hooked_model, fsm, cb_at=\"mlp\", layer=layer, gcb_idx=None, input_len=2\n",
    "    )\n",
    "    pure = len([p for code, p in partitions2.items() if len(p) == 1])\n",
    "    layer_purity_bigrams.append(pure / len(partitions2))\n",
    "\n",
    "    partitions3 = fsm_utils.partition_input_space_with_codebook(\n",
    "        hooked_model, fsm, cb_at=\"mlp\", layer=layer, gcb_idx=None, input_len=3\n",
    "    )\n",
    "    pure = len([p for code, p in partitions3.items() if len(p) == 1])\n",
    "    layer_purity_trigrams.append(pure / len(partitions3))\n",
    "\n",
    "layer_purity_bigrams = [100 * x for x in layer_purity_bigrams]\n",
    "layer_purity_trigrams = [100 * x for x in layer_purity_trigrams]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAyAAAAH0CAYAAADFQEl4AAAgAElEQVR4XuydB3hTVf/Hv/emTQotq6Vl76m4UXEhiONFRVEQURRlyh4iioooCqII+goyBScqiOLeoOJAfVUcf1ELCpRdKC2ltLRJm3v/zzlJSlfapDdJc5PvfR4eodyzPucU+8k5v99RdF3XwYcESIAESIAESIAESIAESIAEQkBAoYCEgDKbIAESIAESIAESIAESIAESkAQoIFwIJEACJEACJEACJEACJEACISNAAQkZajZEAiRAAiRAAiRAAiRAAiRAAeEaIAESIAESIAESIAESIAESCBkBCkjIULMhEiABEiABEiABEiABEiABCgjXAAmQAAmQAAmQAAmQAAmQQMgIUEBChpoNkQAJkAAJkAAJkAAJkAAJUEC4BkiABEiABEiABEiABEiABEJGgAISMtRsiARIgARIgARIgARIgARIgALCNUACJEACJEACJEACJEACJBAyAhSQkKFmQyRAAiRAAiRAAiRAAiRAAhQQrgESIAESIAESIAESIAESIIGQEaCAhAw1GyIBEiABEiABEiABEiABEqCAcA2QAAmQAAmQAAmQAAmQAAmEjAAFJGSo2RAJkAAJkAAJkAAJkAAJkAAFhGuABEiABEiABEiABEiABEggZAQoICFDzYZIgARIgARIgARIgARIgAQoIFwDJEACJEACJEACJEACJEACISNAAQkZajZEAiRAAiRAAiRAAiRAAiRAAeEaIAESIAESIAESIAESIAESCBkBCkjIULMhEiABEiABEiABEiABEiABCgjXAAmQAAmQAAmQAAmQAAmQQMgIUEBChpoNkQAJkAAJkAAJkAAJkAAJUEC4BkiABEiABEiABEiABEiABEJGgAISMtRsiARIgARIgARIgARIgARIgALCNUACJEACJEACJEACJEACJBAyAhSQkKFmQyRAAiRAAiRAAiRAAiRAAhQQrgESIAESIAESIAESIAESIIGQEaCAhAw1GyIBEiABEiABEiABEiABEqCAcA2QAAmQAAmQAAmQAAmQAAmEjAAFJGSo2RAJkAAJkAAJkAAJkAAJkAAFhGuABEiABEiABEiABEiABEggZAQoICFDzYZIgARIgARIgARIgARIgAQoIFwDJEACJEACJEACJEACJEACISNAAQkZajZEAiRAAiRAAiRAAiRAAiRAAeEaIAESIAESIAESIAESIAESCBkBCkjIULMhEiABEiABEiABEiABEiABCgjXAAmQAAmQAAmQAAmQAAmQQMgIUEBChpoNkQAJkAAJkAAJkAAJkAAJUEC4BkiABEiABEiABEiABEiABEJGgAISMtRsiARIgARIgARIgARIgARIgALCNUACJEACJEACJEACJEACJBAyAhSQkKFmQyRAAiRAAiRAAiRAAiRAAhQQrgESIAESIAESIAESIAESIIGQEaCAhAw1GyIBEiABEiABEiABEiABEqCAcA2QAAmQAAmQAAmQAAmQAAmEjAAFJGSo2RAJkAAJkAAJkAAJkAAJkAAFhGuABEiABEiABEiABEiABEggZAQoICFDzYZIgARIgARIgARIgARIgAQoIFwDJEACJEACJEACJEACJEACISNAAQkZajZEAiRAAiRAAiRAAiRAAiRAAeEaIAESIAESIAESIAESIAESCBkBCkjIULMhEiABEiABEiABEiABEiABCgjXAAmQAAmQAAmQAAmQAAmQQMgIUEBChpoNkQAJkAAJkAAJkAAJkAAJUEC4BkiABEiABEiABEiABEiABEJGgAISMtRsiARIgARIgARIgARIgARIgALCNUACJEACJEACJEACJEACJBAyAhSQkKFmQyRAAiRAAiRAAiRAAiRAAhQQrgESIAESIAESIAESIAESIIGQEaCAhAw1GyIBEiABEiABEiABEiABEqCAcA2QAAmQAAmQAAmQAAmQAAmEjAAFJGSo2RAJkAAJkAAJkAAJkAAJkAAFhGuABEiABEiABEiABEiABEggZAQoICFDzYZIgARIgARIgARIgARIgAQoIFwDJEACJEACJEACJEACJEACISNAAQkZajZEAiRAAiRAAiRAAiRAAiRAAeEaIAESIAESIAESIAESIAESCBkBCkjIULMhEiABEiABEiABEiABEiABCgjXAAmQAAmQAAmQAAmQAAmQQMgIUEBChpoNkQAJRCKB4/kFOOfK0XjwztswsG+vSoc4fMoTsFpjsfTxOyMRRViNac/+Q3jv001yThom1vOpb8tefg8rX/sAP3/yrE/v8yUSIAESIIHqEaCAVI8bS5EACZCAJOCPgDw473nExsRgxp23kV6QCXz/858YMXUe1q18BJ3bt/SptbXvb8S6D77C68sf8ul9vkQC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"
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = go.Figure()\n",
    "fig.add_scatter(\n",
    "    x=list(range(hooked_model.cfg.n_layers)),\n",
    "    y=layer_purity_bigrams,\n",
    "    mode=\"lines\",\n",
    "    name=\"bigram\",\n",
    ")\n",
    "fig.add_scatter(\n",
    "    x=list(range(hooked_model.cfg.n_layers)),\n",
    "    y=layer_purity_trigrams,\n",
    "    mode=\"lines\",\n",
    "    name=\"trigram\",\n",
    ")\n",
    "fig.update_xaxes(tick0=0, dtick=1)\n",
    "fig.update_layout(\n",
    "    xaxis_title=\"MLP Layer\",\n",
    "    yaxis_title=\"Pure Codes (%)\",\n",
    "    font=dict(\n",
    "        size=16,\n",
    "    ),\n",
    "    width=800,\n",
    "    legend=dict(\n",
    "        orientation=\"h\",\n",
    "        yanchor=\"bottom\",\n",
    "        y=1.02,\n",
    "        xanchor=\"auto\",\n",
    "        x=0.5,\n",
    "    ),\n",
    ")\n",
    "fig.show(renderer=\"png\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "We see from the plot that the levels of purity are very high on both bigram and trigram inputs at Layer 1 MLP. Because the number of hidden states is 128, and there are 1000 trigram combinations for the model to learn, the network cannot allocate each state to a different neuron. The high purity of the codes demonstrates that codebook training has mostly resolved the **superposition** problem at the first layer. Code purity declines in higher layers as the model forms its prediction of the next token (see the last plot of this notebook)."
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Steering the Network by Intervening on the State Codes\n",
    "\n",
    "We want to measure the causal effect of the codes on predicting the output distribution for bigrams (states) and trigrams. To do this, we pass some random state $S_a$ as the input and intervene with the code(s) at some components of another state $S_b$ and measure the Jensen-Shannon divergence between the resulting output distribution and the original output distribution of $S_b$. We do this for all possible pairs of states $(S_a, S_b)$. We can then average the JS divergence over all pairs of states to get a measure of the causal effect of the code at different components on the output distribution."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 100/100 [00:01<00:00, 61.84it/s]\n"
     ]
    }
   ],
   "source": [
    "import torch.nn.functional as F\n",
    "from tqdm import tqdm\n",
    "\n",
    "\n",
    "def generate_all_valid_inputs_with_prefix(\n",
    "    fsm, is_trigram, prefix_random_states_len, seed=42\n",
    "):\n",
    "    assert prefix_random_states_len >= 0 and prefix_random_states_len <= 63\n",
    "    rev_fsm = fsm.reverse()\n",
    "    rng = np.random.default_rng(seed=seed)\n",
    "    repeat = 3 if is_trigram else 2\n",
    "    chars = [str(i) for i in range(fsm.representation_base)]\n",
    "    all_valid_inputs = [\n",
    "        \"\".join(comb)\n",
    "        for comb in itertools.product(chars, repeat=repeat)\n",
    "        if fsm_utils.valid_input(\"\".join(comb), fsm)\n",
    "    ]\n",
    "    start_states = [s[0] for s in fsm.seq_to_traj(all_valid_inputs)]\n",
    "    random_state_prefix = rev_fsm.generate_trajectories(\n",
    "        prefix_random_states_len, start_states=start_states\n",
    "    )\n",
    "    random_state_prefix = random_state_prefix[:, ::-1]\n",
    "    random_state_prefix = random_state_prefix.astype(int)\n",
    "    prefix_to_hide = rng.integers(\n",
    "        0, prefix_random_states_len + 1, len(all_valid_inputs)\n",
    "    )\n",
    "    final_token_pos = 2 * (prefix_random_states_len - prefix_to_hide) + repeat\n",
    "    final_token_pos = torch.tensor(final_token_pos, device=hooked_model.cfg.device)\n",
    "    random_state_prefix = [\n",
    "        fsm.traj_to_str(traj[prefix_to_hide[i] :])\n",
    "        for i, traj in enumerate(random_state_prefix)\n",
    "    ]\n",
    "    all_valid_inputs_w_prefix = [\n",
    "        random_state_prefix[i] + all_valid_inputs[i]\n",
    "        for i in range(len(all_valid_inputs))\n",
    "    ]\n",
    "    all_valid_inputs_w_prefix_tokens = tokenizer(\n",
    "        all_valid_inputs_w_prefix, padding=True, return_tensors=\"pt\"\n",
    "    )[\"input_ids\"]\n",
    "    all_valid_inputs_w_prefix_tokens = F.pad(\n",
    "        all_valid_inputs_w_prefix_tokens, (1, 0), value=tokenizer.bos_token_id\n",
    "    )\n",
    "    all_valid_inputs_w_prefix_tokens = all_valid_inputs_w_prefix_tokens.to(device)\n",
    "\n",
    "    return all_valid_inputs, all_valid_inputs_w_prefix_tokens, final_token_pos\n",
    "\n",
    "\n",
    "(\n",
    "    all_valid_inputs,\n",
    "    all_valid_inputs_w_prefix_tokens,\n",
    "    final_token_pos,\n",
    ") = generate_all_valid_inputs_with_prefix(\n",
    "    fsm,\n",
    "    is_trigram=False,\n",
    "    prefix_random_states_len=0,  # change to 62 to reproduce the results in the paper\n",
    ")\n",
    "\n",
    "js_divs = {}\n",
    "all_state_info = {}\n",
    "# store the logits and cache of all valid inputs without any random prefix.\n",
    "for input in tqdm(all_valid_inputs):\n",
    "    input_tensor = hooked_model.to_tokens(str(input), prepend_bos=True).to(device)\n",
    "    logits, cache = hooked_model.run_with_cache(input_tensor)\n",
    "    all_state_info[input] = (logits, cache)\n",
    "\n",
    "for iter_a, input_a in enumerate(all_valid_inputs[: len(all_state_info)]):\n",
    "    for input_b in all_valid_inputs[iter_a + 1 : len(all_state_info)]:\n",
    "        js_divs[(input_a, input_b)] = cb_utils.JSD(\n",
    "            all_state_info[input_a][0], all_state_info[input_b][0]\n",
    "        ).item()\n",
    "\n",
    "avg_js_div = sum(js_divs.values()) / len(js_divs)\n",
    "all_states_logits = torch.cat([v[0] for v in all_state_info.values()], dim=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 100/100 [00:18<00:00,  5.47it/s]\n"
     ]
    },
    {
     "data": {
      "image/png": "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"
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from functools import partial\n",
    "\n",
    "patchings_to_plot_orig = [\n",
    "    \"none\",\n",
    "    \"l0_attn\",\n",
    "    \"l1_mlp\",\n",
    "    \"all_attn\",\n",
    "    \"all_mlp\",\n",
    "    \"all_attn_mlp\",\n",
    "]\n",
    "patchings_to_plot = [s.replace(\"all\", \"l0,l1,l2,l3\") for s in patchings_to_plot_orig]\n",
    "\n",
    "js_divs_for_patching = {k: 0 for k in patchings_to_plot}\n",
    "js_divs_for_patching[\"none\"] = 0\n",
    "\n",
    "for state_b, input_b in tqdm(enumerate(all_valid_inputs), total=len(all_valid_inputs)):\n",
    "    js_divs_w_b = cb_utils.JSD(\n",
    "        all_states_logits[:, -1],\n",
    "        all_states_logits[state_b % len(all_state_info), -1].unsqueeze(0),\n",
    "        reduction=\"none\",\n",
    "    ).sum()\n",
    "    js_divs_w_b /= all_states_logits.shape[0] - 1  # removing b as JSD(b,b) = 0\n",
    "    js_divs_for_patching[\"none\"] += js_divs_w_b\n",
    "\n",
    "    for patching in patchings_to_plot:\n",
    "        if patching == \"none\":\n",
    "            continue\n",
    "        cb_at = patching.split(\"_\")[1:]\n",
    "        layers = fsm_utils.get_layers_from_patching_str(patching)\n",
    "        heads = [None] * len(cb_at)\n",
    "        if \"attn\" in cb_at:\n",
    "            attn_idx = cb_at.index(\"attn\")\n",
    "            cb_at.pop(attn_idx), heads.pop(attn_idx)\n",
    "            cb_at += [\"attn\"] * hooked_model.cfg.n_heads\n",
    "            heads += list(range(hooked_model.cfg.n_heads))\n",
    "        cb_at_rep = cb_at * len(layers)\n",
    "        heads_rep = heads * len(layers)\n",
    "        layers_rep = []\n",
    "        for l in layers:\n",
    "            layers_rep += [l] * len(cb_at)\n",
    "\n",
    "        cache_b = all_state_info[input_b][1]\n",
    "        code = [\n",
    "            cache_b[\n",
    "                cb_utils.get_cb_hook_key(cb_at_rep[i], layers_rep[i], heads_rep[i])\n",
    "            ][0, -1, :]\n",
    "            for i in range(len(cb_at_rep))\n",
    "        ]\n",
    "\n",
    "        mod_logits, mod_cache = fsm_utils.run_with_codes_var_pos(\n",
    "            all_valid_inputs_w_prefix_tokens,\n",
    "            hooked_model,\n",
    "            code,\n",
    "            cb_at_rep,\n",
    "            layers_rep,\n",
    "            heads_rep,\n",
    "            pos=final_token_pos,\n",
    "        )\n",
    "        a, b, c = dims(sizes=mod_logits.shape)\n",
    "        mod_logits_final = mod_logits[a, final_token_pos[a], c].order(a, c)\n",
    "        js_divs_w_b = cb_utils.JSD(\n",
    "            mod_logits_final,\n",
    "            all_states_logits[state_b % len(all_state_info), -1].unsqueeze(0),\n",
    "            reduction=\"none\",\n",
    "        ).sum()\n",
    "        js_divs_w_b /= mod_logits_final.shape[0] - 1  # removing b as JSD(b,b) = 0\n",
    "        js_divs_for_patching[patching] += js_divs_w_b\n",
    "\n",
    "js_divs_for_patching = [\n",
    "    js_divs_for_patching[k].item() / len(all_valid_inputs) for k in patchings_to_plot\n",
    "]\n",
    "js_divs_for_patching = [\n",
    "    js_div / max(js_divs_for_patching) for js_div in js_divs_for_patching\n",
    "]\n",
    "\n",
    "fig = go.Figure()\n",
    "x_labels = [\n",
    "    fsm_utils.clean_patching_name(patching) for patching in patchings_to_plot_orig\n",
    "]\n",
    "fig.add_trace(go.Bar(x=x_labels, y=js_divs_for_patching))\n",
    "fig.update_layout(yaxis_title=\"Normalized JS Div\")\n",
    "fig.update_layout(\n",
    "    width=600,\n",
    "    font=dict(\n",
    "        size=16,\n",
    "    ),\n",
    ")\n",
    "fig.show(renderer=\"png\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "As can be seen from the above bar charts, the L1 MLP codes have a higher causal effect on the output distribution than the L1 attention code. This is consistent with our findings that the Layer 1 MLP codes have a one-to-one mapping with the FSM states and the trigrams, while the Layer 1 attention codes are less precise. Additionally, changing every state code in the MLP layer shifts the network's decision almost entirely to that of the activated code, suggesting that these layers almost entirely control the network's predictions in this setting.\n",
    "\n",
    "To look at the tokens different codes from any layer activate on, play around with our webapp in the directory `codebook_features/webapp/`."
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Inputs Grouped by Codes\n",
    "\n",
    "In the later layers of the codebook model, the codes are not one-to-one with the FSM states, as is evident from the code purity plots. Multiple inputs are grouped together into a single code. One reason to group together different states within the last layer could be because they share the same possible next tokens, and the network merges them as it forms a prediction of the next token.\n",
    "\n",
    "We check this hypothesis by comparing the divergence of the output distributions of random states with the divergence of the output distributions of states that are merged in the same code. If our hypothesis is true, we would expect the divergence between the output distributions of states grouped together by codes to be ***smaller*** than the divergence between the output distributions of random states."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 100/100 [00:01<00:00, 61.60it/s]\n",
      "1000it [00:01, 605.43it/s]0<?, ?it/s]\n",
      "1000it [00:01, 595.05it/s]1<00:04,  1.65s/it]\n",
      "1000it [00:01, 609.83it/s]3<00:03,  1.67s/it]\n",
      "1000it [00:01, 610.50it/s]4<00:01,  1.66s/it]\n",
      "100%|██████████| 4/4 [00:06<00:00,  1.66s/it]\n"
     ]
    }
   ],
   "source": [
    "chars = [str(i) for i in range(fsm.representation_base)]\n",
    "all_valid_inputs2 = [\n",
    "    \"\".join(comb)\n",
    "    for comb in itertools.product(chars, repeat=3)\n",
    "    if fsm_utils.valid_input(\"\".join(comb), fsm)\n",
    "]\n",
    "js_divs2 = {}\n",
    "for input in tqdm(all_valid_inputs2):\n",
    "    input_tensor = hooked_model.to_tokens(str(input), prepend_bos=True).to(device)\n",
    "    logits, cache = hooked_model.run_with_cache(input_tensor)\n",
    "    all_state_info[input] = (logits, cache)\n",
    "\n",
    "for iter_a, input_a in enumerate(all_valid_inputs2):\n",
    "    for input_b in all_valid_inputs2[iter_a + 1 : len(all_state_info)]:\n",
    "        js_divs2[(input_a, input_b)] = cb_utils.JSD(\n",
    "            all_state_info[input_a][0], all_state_info[input_b][0]\n",
    "        ).item()\n",
    "\n",
    "code_groups_for_all_comps = {}\n",
    "for layer in tqdm(range(hooked_model.cfg.n_layers)):\n",
    "    code_groups_for_all_comps[\n",
    "        (layer, \"mlp\", None)\n",
    "    ] = fsm_utils.partition_input_space_with_codebook(\n",
    "        cb_model=hooked_model,\n",
    "        fsm=fsm,\n",
    "        layer=layer,\n",
    "        cb_at=\"mlp\",\n",
    "        gcb_idx=None,\n",
    "        input_len=3,\n",
    "    )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAyAAAAEsCAYAAAA7Ldc6AAAgAElEQVR4XuyddXwURx+HvxcPSXB3KdJSHEqBFihetLi7u5bg7sHdXYu7F4fS4lKKu7vFk3s/M/cmJCGQy+3eZpP77j+0MPr8Zvf22ZnZNRiNRiN4kAAJkAAJkAAJkAAJkAAJkIAGBAwUEA0oswoSIAESIAESIAESIAESIAFJgALCgUACJEACJEACJEACJEACJKAZAQqIZqhZEQmQAAmQAAmQAAmQAAmQAAWEY4AESIAESIAESIAESIAESEAzAhQQzVCzIhIgARIgARIgARIgARIgAQoIxwAJkAAJkAAJkAAJkAAJkIBmBCggmqFmRSRAAiRAAiRAAiRAAiRAAhQQjgESIAESIAESIAESIAESIAHNCFBANEPNikiABEiABEiABEiABEiABCggHAMkQAIkQAIkQAIkQAIkQAKaEaCAaIaaFZEACZAACZAACZAACZAACVBAOAZIgARIgARIgARIgARIgAQ0I0AB0Qw1KyIBEiABEiABEiABEiABEqCAcAyQAAmQAAmQAAmQAAmQAAloRoACohlqVkQCJEACJEACJEACJEACJEAB4RggARIgARIgARIgARIgARLQjAAFRDPUrIgESIAESIAESIAESIAESIACwjFAAiRAAiRAAiRAAiRAAiSgGQEKiGaoWREJkAAJkAAJkAAJkAAJkAAFhGOABEiABEiABEiABEiABEhAMwIUEM1QsyISIAESIAESIAESIAESIAEKCMcACZAACZAACZAACZAACZCAZgQoIJqhZkUkQAIkQAIkQAIkQAIkQAIUEI4BEiABEiABEiABEiABEiABzQhQQDRDzYpIgARIgARIgARIgARIgAQoIBwDJEACJEACJEACJEACJEACmhGggGiGmhWRAAmQAAmQAAmQAAmQAAlQQDgGSIAESIAESIAESIAESIAENCNAAdEMNSsiARIgARIgARIgARIgARKggHAMkAAJkAAJkAAJkAAJkAAJaEaAAqIZalZEAiRAAiRAAiRAAiRAAiRAAeEYIAESIAESIAESIAESIAES0IwABUQz1KyIBEiABEiABEiABEiABEiAAsIxQAIkQAIkQAIkQAIkQAIkoBkBCohmqFkRCZAACZAACZAACZAACZAABYRjgARIgARIgARIgARIgARIQDMC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ClCAAhSgAAUoQAEKUIABCMsABShAAQpQgAIUoAAFKGA3AQYgdqPmhShAAQpQgAIUoAAFKEABBiAsAxSgAAUoQAEKUIACFKCA3QQYgNiNmheiAAUoQAEKUIACFKAABRiAsAxQgAIUoAAFKEABClCAAnYTYABiN2peiAIUoAAFKEABClCAAhRgAMIyQAEKUIACFKAABShAAQrYTYABiN2oeSEKUIACFKAABShAAQpQgAEIywAFKEABClCAAhSgAAUoYDcBBiB2o+aFKEABClCAAhSgAAUoQAEGICwDFKAABShAAQpQgAIUoIDdBBiA2I2aF6IABShAAQpQgAIUoAAFGICwDFCAAhSgAAUoQAEKUIACdhNgAGI3al6IAhSgAAUoQAEKUIACFGAAwjJAAQpQgAIUoAAFKEABCthNgAGI3ah5IQpQgAIUoAAFKEABClCAAQjLAAUoQAEKUIACFKAABShgNwEGIHaj5oUoQAEKUIACFKAABShAAQYgLAMUoAAFKEABClCAAhSggN0EGIDYjZoXogAFKEABClCAAhSgAAUYgLAMUIACFKAABShAAQpQgAJ2E2AAYjdqXogCFKAABShAAQpQgAIUYADCMkABClCAAhSgAAUoQAEK2E2AAYjdqHkhClCAAhSgAAUoQAEKUIABCMsABShAAQpQgAIUoAAFKGA3AQYgdqPmhShAAQpQgAIUoAAFKEABBiAsAxSgAAUoQAEKUIACFKCA3QQYgNiNmheiAAUoQAEKUIACFKAABf4PT5N9PEa9M1UAAAAASUVORK5CYII="
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from plotly.subplots import make_subplots\n",
    "\n",
    "fig = make_subplots(\n",
    "    rows=1,\n",
    "    cols=3,\n",
    "    shared_yaxes=True,\n",
    "    subplot_titles=[f\"Layer {i}\" for i in range(1, 4)],\n",
    ")\n",
    "fig.update_layout(title=None, width=800, height=300)\n",
    "fig.update_layout(\n",
    "    legend=dict(\n",
    "        orientation=\"h\",\n",
    "        yanchor=\"bottom\",\n",
    "        y=1.2,\n",
    "        xanchor=\"auto\",\n",
    "        x=0.5,\n",
    "    )\n",
    ")\n",
    "\n",
    "fig_kwargs = dict(row=1, col=1, showlegend=True)\n",
    "fig = fsm_utils.plot_js_div(\n",
    "    code_groups_for_all_comps, 1, \"mlp\", None, js_divs2, fig=fig, **fig_kwargs\n",
    ")\n",
    "fig_kwargs = dict(row=1, col=2, showlegend=False)\n",
    "fig = fsm_utils.plot_js_div(\n",
    "    code_groups_for_all_comps, 2, \"mlp\", None, js_divs2, fig=fig, **fig_kwargs\n",
    ")\n",
    "fig_kwargs = dict(row=1, col=3, showlegend=False)\n",
    "fig = fsm_utils.plot_js_div(\n",
    "    code_groups_for_all_comps, 3, \"mlp\", None, js_divs2, fig=fig, **fig_kwargs\n",
    ")\n",
    "\n",
    "fig.update_xaxes(title_text=\"JS Divergence\")\n",
    "fig.update_yaxes(title_text=\"Probability\", row=1, col=1)\n",
    "fig.show(renderer=\"png\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "From the above plots we observe that the trigram inputs that are grouped together have a significantly smaller JS Divergence than the random trigram input pairs, which supports our hypothesis."
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.6"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
