{
  "cells": [
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "Rmmy4f2nnPeq"
      },
      "source": [
        "# Toy Models of Feature Absorption\n",
        "\n",
        "In \"A is for Absorption: Studying Feature Splitting and Absorption in Sparse Autoencoders\" we find evidence for a phenomenon we call \"Feature absorption\", where a latent which seems to track a concept has arbitrary holes in its recall. We hypothesized that this is due to the sparsity penalty incentiving the SAE to partially merge features that co-occur together to increase sparsity.\n",
        "\n",
        "In this notebook, we set up a toy model where we can explicitly control feature representations and co-occurrence patterns, and show that feature absorption occurs in this toy setting when features co-occur.\n"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "yaCVSd975vao"
      },
      "source": [
        "## Install dependencies"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "VDNCr-l5BkL9",
        "outputId": "1f8f1f9f-7b08-44be-f7ce-46ad0f5b2eae"
      },
      "outputs": [],
      "source": [
        "!apt-get install texlive-latex-extra texlive-fonts-recommended dvipng cm-super\n",
        "!pip install sae-lens rich tueplots"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "fa0ZiXFppUND"
      },
      "source": [
        "## Controlling feature firing and co-occurrence\n",
        "\n",
        "Below, we set up a function `get_training_batch()` which we can use to control how many ground-truth features we have, their firing probabilities and magnitudes, and an option `modify_firing_features` callback which can be used to modify the firing features in a batch, for instance forcing a feature to fire or not fire depending on other firing features."
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "Ih6sU_tdCKb9"
      },
      "outputs": [],
      "source": [
        "import torch\n",
        "from typing import Callable\n",
        "\n",
        "DEFAULT_DEVICE = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\n",
        "DEFAULT_D_IN = 50\n",
        "DEFAULT_D_SAE = 4\n",
        "DEFAULT_NUM_FEATS = 4\n",
        "\n",
        "def get_training_batch(\n",
        "    batch_size: int,\n",
        "    firing_probabilities: torch.Tensor, # these are the independent probabilities of each feature firing\n",
        "    std_firing_magnitudes: torch.Tensor | None = None, # If not provided, the stdev of magnitudes will be 0\n",
        "    device: torch.device = DEFAULT_DEVICE,\n",
        "    modify_firing_features: Callable[[torch.Tensor], torch.Tensor] | None = None,\n",
        "):\n",
        "    firing_features = torch.bernoulli(\n",
        "        firing_probabilities.unsqueeze(0).expand(batch_size, -1).to(device)\n",
        "    )\n",
        "    if std_firing_magnitudes is None:\n",
        "        std_firing_magnitudes = torch.zeros_like(firing_probabilities)\n",
        "    if modify_firing_features is not None:\n",
        "        firing_features = modify_firing_features(firing_features)\n",
        "    firing_features = firing_features.to(device)\n",
        "    firing_magnitude_delta = torch.normal(\n",
        "        torch.zeros_like(firing_probabilities).unsqueeze(0).expand(batch_size, -1).to(device),\n",
        "        std_firing_magnitudes.unsqueeze(0).expand(batch_size, -1).to(device)\n",
        "    )\n",
        "    firing_magnitude_delta[firing_features == 0] = 0\n",
        "    return firing_features + firing_magnitude_delta"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "RcGYfRb8p5_W"
      },
      "source": [
        "## Creating a toy model\n",
        "\n",
        "Our toy model is simply a decoder which maps the features into a hidden dimension. The decoder is randomly initialized and we adjust the embeddings to be as orthogonal as possible from each other. If the hidden dim is less than the number of features, the features will be in superposition. To start with, we will use fully orthogonal features not in superposition. The decoder of the toy model is the \"true direction\" for each feature. Our hope is that a trained SAE will perfectly recover these true features directions."
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "5DDxUiJQFQLM"
      },
      "outputs": [],
      "source": [
        "import torch\n",
        "from transformer_lens.hook_points import HookedRootModule\n",
        "from typing import Any\n",
        "\n",
        "def cos_sims(mat1: torch.Tensor, mat2: torch.Tensor):\n",
        "    return (mat1 / (mat1.norm(dim=0, keepdim=True))).T @ (mat2 / (mat2.norm(dim=0, keepdim=True)))\n",
        "\n",
        "class ToyModel(HookedRootModule):\n",
        "    def __init__(self, num_feats: int = DEFAULT_NUM_FEATS, hidden_dim: int = DEFAULT_D_IN):\n",
        "        super().__init__()\n",
        "        self.decoder = torch.nn.Linear(num_feats, hidden_dim)\n",
        "        torch.nn.init.orthogonal_(self.decoder.weight)\n",
        "        self.setup()\n",
        "\n",
        "    def forward(self, x: torch.Tensor, **kwargs: Any):\n",
        "        x = self.decoder(x)\n",
        "        return x\n",
        "\n",
        "toy_model = ToyModel().to(DEFAULT_DEVICE)"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "b4HCdrh-SZdg"
      },
      "source": [
        "Let's check that our true features are orthogonal to each other"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 383
        },
        "id": "UkOUiBN5SYlC",
        "outputId": "75e3a4d7-46d1-497f-aee4-df1adc6872ad"
      },
      "outputs": [
        {
          "data": {
            "image/png": "iVBORw0KGgoAAAANSUhEUgAAAW4AAAFuCAYAAAChovKPAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjAsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvlHJYcgAAAAlwSFlzAAAXEgAAFxIBZ5/SUgAAJi9JREFUeJzt3V9sG1e+H/CvyJutU8RDtq+bMfpSu9HIxV10jV2P0Je1YSpZ9MECdrlvK+aasqBrhwss1SKFwiBM0IsuGWCV9RWWlhpq+0TqgXko1qICZV8Kj1AExV50NXaFvlz4+LkVx0aTrkGxD8LMJcW/hxrpaMjvBxgknD9nDkX6xx9/58xwotFoNEBERIERUt0BIiKS8xeqO0BEpJrjONja2kK5XEalUhnomFwuBwCIRqM4ODjA0tKS1PaTYOAmorFm2zYsywJwFMAHUS6XEY1GkUwmAQCWZSGRSKBYLA60/aRYKiGisWYYBpLJJHRdH/iYfD4P0zS9x6ZpwrIsCCEG2n5SzLiJaGTU63UcHh62rQ+FQgiHw76cQwgBx3HaAr2mabBtGwB6bpf5gOiGgZuIlPvO9971pZ1P3/0eHjx40Lb+3r17uH//vi/n6FZOiUQiqNVqfbf7gYGbiEbG4uIiFhYW2taHQqdfFe4VtAfZLoOBm4iUmwj5U8YIh8O+lUS60TSt43q3PNJvux84OElEyk2Ewr4sZ8ENzp0GGg3D6LvdDwzcRKTceQ7cjuN4c7Jd8/Pz3hRC4Gi6XywW8zLqfttPaoKXvBORaq//4K99aeeb//a30scIIVAqlbC7uwvbtnHnzp2WOdi2bWNubg6VSqUl8DZfYCOEQDqdbimT9Nt+EgzcRKTcP77+ni/t/N/dz3xp57zj4CQRKTdxygOKo4aBm4iUC53RwOKo4OAkEVHAMOMmIuXOairfqGDgJiLlGLjlMHATkXITZ3BJ+ijhX4uIKGCYcRORciyVyGHgJiLlGLjlsFRCRBQwzLiJSDlm3HIYuIlIOV7yLoeBm4iUY8YthzVuIqKAYcZNRMox45bDwE1EyvHugHIYuIlIOWbccljjJiIKGGbcRKQcM2455ybjzmQyuHLlCq5du4abN2/i5s2b3uPZ2Vnv8ZUrV5T2c21tDWtra7h58ybee8+f38kjoFqt4tq1axBCqO4KAP/706k927axtrbW8mvgfrZ/kv3O2nn+lffz6NwE7oODA9y5cwdff/01dnZ2kM1mAQDXr19HpVLBzs4OdnZ2lPZxbW0NQggkk0msrKzgxYsXvrTrOI4v7QSZpmnQdR2RSER1VwD435/j7dm2jUKhgHw+70sQ7dbf4++t8/Z3djFwyzk3gTsajWJpaannPrquIx6Pn1GP2j18+BC6rgMADMNAsVg8cZuO4yCVSp24naAzTROVSgWapqnuCgD/+3O8PcMwcPfuXV/a7tQ+0Pm9dd7+zjScc1PjTiaTvu53Gk4jM06lUufuayudjdMOnkF6b41TtuyHcxO43Ux2kP0cx0G5XEa5XEalUkEqlcLe3h7ef/99vP/++9A0DV9//TWAo/JGPp+HYRioVCpeO+VyGbZtY29vD5FIBNlstmsfqtUqHj16BADY2tqCEAK6rnsfIr3achwH+Xweuq5DCAEhBFZWVqBpGqrVKvb29uA4DjKZDHRdh67rSKVSfZ9Dt7/BV199BU3TevbJtm2Uy2Xouu7VVwf59mBZFqrVKgBgb28P8Xi85RtQtVqFZVm4ePEinjx5gsnJyZZvUd3O6zgOtra2UK1WEY/HMTMzA9u28ejRI2xvb6NSqWB5eRm7u7vQdR0rKyttr5XM6zlMf4QQKJVKXn8KhQI2NzcRiUSwsrICwzCQyWRgWRZqtRpWVlZgmqb3Wh1vr5te75dur/kXX3yBx48ft7Tf6b0Vj8e79uM03i8yeK8SSY1z6vHjx43Lly837t+/33HbjRs3GpcvX248fPiwUSqVGrdv327UarXG3Nxc4/vf/37L/rdv327cvn3be/zw4cPG1tZWy/bjxxxXq9W88zXr19bt27dbnsONGzdaHs/NzTVu3LjR0uYgz6HX36Bfn27cuNHY29trOV8/pVKppd8PHz5sXL58ufH48WPvcXP/arVa48aNGy3rup332bNnjV/96leNy5cve/12X8vLly83Pvjgg8azZ8+6vieGeT2H6c/9+/e9/rjH3b59u3Hjxg2vj83rXJ3ac9dfvny5USqVWvre7f3S7TV/8uRJx/aPv7e69eM03i+y9J//Z1+WcXFuatwyTNP0spmZmRnE43Gvbnfx4sWexzqOg4cPH7ZkG2+//TYcx/GyyUEN0lYkEsHVq1e97ZOTk3jy5EnPdvs9B6D73wBA3z4JIbC3t+dt71d+crO25uw5Ho8jFot534Dy+Tzm5+e97ZqmIZlMwrbtvufVdR3vvPNOyzk1TcPk5CQAeNmf+5yb/34neT1l+zM9Pe3tZxiGdy4hBOLxuJehuuvc0lqn9rrp9X7p9pq/9dZbA7XfqR+D/P1k3y/D4OCknHNTKhnWoCUWl/tVL5PJtKyPx+PSNcdB2mr+Slkul/sG7WE0/w0G6ZNpmshkMrBtG+l02gsG3bhtNp9H0zR89tlnXbcDRwHALR/MzMxIn7eTixcvolarST3fbvzoj3uO5nO5/1+r1aTfU4O+X2Tf992cxvtlGOMUdP0Q+MAtyx2scacbnkVbzdMIHz9+fCrBW6ZPKysrSKVSKJfL2NraaqnH9mqz33YhhJeJAv8QwNztsucdxElez9Pojx+C/n4ZBgO3nECWSk7KcZyOM0SGmTXSr61EIoE//elPAw2W+aVfnzRNQ7FYxMrKitfHXsH5eAA+zn1e3ba7JQ/Z8w5q2NfztPpzEqPwfqHTNxaBu/mN6WaEy8vLbfuUy2Wpdvu1Zds2LMvyaqPdNH/176bbPy7ZPgHw/jszM+PVxXtdvTc1NQUAyOVyLeuFEKhWq972ra2ttnMC8J6/7HkHcZLX8zT6cxKDvl9k9Htvncb7ZRih0IQvy7g4t4Hb/Ucve3Xi1atX4TiO93VzbW0NwFGQyWQyME0ThmFge3sb7733HqrVKnK5HFKp1EAX9xwcHHj/P2hb5XIZQgivZulO83IcxxvcE0J4/xj6PYdeBulTc0DTdR2apnnBtxPDMGCaJra3t5FIJFAul5HL5ZDL5TAzMwNN05DNZr3A4yoUCojH497X6l7nHeTDCzh6PzR/gJ3k9fSjP65+GX+n9rp9EPd6v3TTqf1O763j+53G+2UYE6EJX5ZxcS4Dd7lcRj6fB3D0ye4GMFe1WvWyu0wm07ItmUzCNE3k83mkUimYponJyUnEYjFv5HxjYwOxWAy7u7v44IMPWubKdmLbtpeRbG9vt8xW6NWWYRiIx+OwbRupVAq6riObzULTNORyOW/mhaZpSCQS3j/MQZ5Dr7/BIM8vkUhgbW0NmUwG6XS6pTbdSbFYRDwex97eHvL5PF68eOENTgJHg1nFYtFrM5fLIRqNttVOO53XvWcHcDQjxv0A2N7e9p6fO8vBDUDu/sO8nsP0x53LDBx98xBCtKwrFAo913Vqr1AoAPiHOdT93i+WZXV8zTu1D6DtvdVtv9N4v8iamJjwZRkXE41Go6G6E0Q03v75X3/hSzv/629v+9LOINwL8VQYu1klRHT+nIf6tDuGE41GcXBw0PfeSW4loHkOv8swDO9qW3fMQgiBSCTS88rZQTFwE5FyquvT5XIZ0WjUu7jIsiwkEomel/a7YwfHB2rj8Tiy2SyEENjc3MT6+jp0XUcsFuv7YTAoBm4iUk514M7n89jY2PAem6bpTXvsVg7RdR37+/st6zKZTMu4zsbGhu/jAcA5HZwkIhpGvV7Hq1ev2pZ6vd71mOYZXs00TfMGcDs5ful/LpdDOp1u28+9OZufdxdl4CYi5UITE74sq6urmJqaaltWV1e7nrtbQI1EIj2nhTYH+mq1iunp6baZTIVCwbvPzvLysvT9kLphqYSIlPOrVLK4uIiFhYW29aGQfI5aq9UGypLdi5WO18ObbwoGAHfv3sXs7GxbeWUYzLiJaGSEw2G89tprbUu4x/2+u83371Q+6WRra8u7rUOz49m125YfV50ycBORciqvnHSvBu10/5VBBhbL5TIuXbrUtj6VSrXUyN2yix9zvxm4iUg51fcqmZ+fb8mELcvy7jcPHGXfx+/V4+o2gHl8fne1Wm1p8yRY4yYi5SYUp5DJZNK7/040GoUQAp988om33Z2T/bOf/awt8Oq63vHeLel0GoVCwbugB0DLbSJOQskl79/53rtnfcpzobbbfWSbaJS8fuGC1P5/+e8f+XLev/sPg/3SUNAx4yYi5cbpBlF+YOAmIuXOw71KgoSBm4iUU33Je9BwVgkRUcAw4yYi5Zhxy2HgJiLlQhyclMJSCRFRwDDjJiLlWCqRw8BNRMoxcMth4CYi5TiPWw5r3EREAcOMm4iU4yXvchi4iUg51XcHDBoGbiJSjjVuOfycIyIKGGbcRKQcpwPKYeAmIuU4OCmHgZuIlGONWw5r3EREAcOMm4iUY41bDgM3ESkXZuCWwlIJEVHAMOMmIuWYccth4CYi5Ri45TBwE5FyDNxyWOMmIgoYZtxEpBwzbjkM3ESk3F8wcEtpCdwvX75EuVyGZVkQQgAAJicncfXqVcTjcbzxxhtKOklEo40Ztxyvxi2EwI9+9CP8/ve/x3e/+13cunULt27dgqZpePz4MW7cuIGnT5+q7CsREaEp415fX8dXX32FixcvdtzRcRx8+umn+Oijj86sc0Q0Hphxy/ECt2EYXYM2AGiahqmpqTPpFBGNl3CIE9xkeIF7b28Ply5dwg9/+MOOO+7u7mJvbw8/+clPzqxzRDQezkPGncvlAADRaBQHBwdYWlrqub8QAqVSCdPT097jSCSCmZmZodsclBe4l5aW8POf/xxPnz6Frute9v3ixQsIITA5OYnf/e53vpyUiOg8KZfLiEajSCaTAADLspBIJFAsFrseI4TA5uYm1tfXoes6YrFYS2Aeps1BTTQajUbzCtu2Yds29vb2AACXLl2CaZqYnJw88clc3/neu761FSS13VXVXSA6E69fuCC1//zm3/ly3oc//cuhjrt27Ro2NjZgGIa37sqVK9jZ2YGu6x2PsSwLkUik5ZiTtjmotnnchmHAMAz89Kc/PVHDRESDUlkqEULAcZy2YKppGmzb7htkLcuC4zgwTROapvnSZj8cESCikVGv1/Hq1au2pV6vdz3GcZyO6yORCGq1Ws/zFQoF6LoO0zSxvLyMarV64jYHwSsniUi5sE8/Fry6uooHDx60rb937x7u378v1VatVusagAHANE2Ypuk9vnv3LmZnZ7G/vz90m4Ni4CYi5fwqlSwuLmJhYaFtfajHdEO3vHFcp1JHs2q12jKDxN3Xsqyux/Vrc1AslRCRcuHQhD9LOIzXXnutbQmHw13Pres6NE3zbvPRrNvAIwCkUinYtu09dksguq4P3eagGLiJaOzNz8/DsizvsWVZiMViXnbsOI43J9sVj8dbsudqtdpyTL82T6JtOuBZ4HRAotEmOx3w3/4Xu/9OA/jVvxk+m22+WEYIgXQ67ZVRbNvG3NwcKpVKSzAvFArexTUA2i6w6dXmSTBwnyEGbhoXsoH7/d8/8eW8f/Nj/643Oc84OElEyp2HS96DhDVuIqKAYcZNRMox45bDwE1EyjFwy2HgJiLlGLjlsMZNRBQwzLiJSDlm3HIYuIlIOQZuOSyVEBEFDDNuIlKOGbccBm4iUo6BWw4DNxEpx8AthzVuIqKAYcZNRMr59dNl44KBm4iUCzFwS2HgJiLlwozbUljjJiIKGGbcRKRciLNKpDBwE5FyHJyUoyRwj+tvL0auL6rughLj+nrT4Dg4KYc1biKigGGphIiU46wSOQzcRKQcByflsFRCRBQwzLiJSDkOTsph4CYi5VjjlsPATUTKMeOWwxo3EVHAMOMmIuX4QwpyGLiJSDmWSuQwcBORchyclMMaNxFRwDDjJiLlWCqRw8BNRMqdh8HJXC4HAIhGozg4OMDS0lLP/R3HQaFQAAAIIQAAn3zyCTRN89aVSiVMT097jyORCGZmZk7cVwZuIhp75XIZ0WgUyWQSAGBZFhKJBIrFYtdj8vk8stms9ziTyWB2dhY7OzsAjgL15uYm1tfXoes6YrFY3w+DQbHGTUTKhSb8WYaVz+dhmqb32DRNWJblZdKdlMtlWJblPU4mkxBCwLZtb93Gxgb29/exs7PjW9AGmHET0Tng1y/g1Ot1HB4etq0PhUIIh8MdjxFCwHEc6Lresl7TNNi23bbelc1mMTU11bdPlmXBcRyYpumVUU6KGTcRKReamPBlWV1dxdTUVNuyutr9V5gcx+m4PhKJoFardT0uHo+3BOJSqQRd12EYhreuUChA13WYponl5WVUq9Uh/jrtmHET0chYXFzEwsJC2/pQSD5HrdVqXYP6cbZtY3t7G5VKxVtnmmZL+eXu3buYnZ3F/v6+dF+OY8ZNRMqFQz4t4TBee+21tqVbmQRA1/JFp/JJJ0II5PN5VCqVlraOZ9duW8118WExcBORcn6VSoah6zo0Tes4ENlc9uhECIG1tTUUi0WvDbedVCrVMlDpll0G+TDoh4GbiJQLT0z4sgxrfn6+JRO2LAuxWMwLso7jePO8XUIIZDIZxONx2LYN27axtraGSCQC4KgG3hykq9VqS5snMdFoNBonbkXSN99+e9anPBci1xdVd0GJ2m73gSEaTa9fuCC1/9fP/o8v57126Z8MfWzzBThCCKTTaa/0Yds25ubmUKlUvMB77dq1jjVwt4btXqDjXtADwLcpgQzcZ4iBm8aFbOD+7+LAl/P+Kz3qSzvnHWeVEJFyYRZtpTBwE5FyvMmUHH7OEREFDDNuIlKOCbccBm4iUi4ERm4ZUqWS58+fn1Y/iIhoQF7G/eWXX/bd+dGjR/j1r399mv0hojHEUokcL3CXSiVYltXztoMvXrw4k04R0Xg5Bz+AEyhe4I7H4/j888977ry9vX3qHSKi8cOMW45X447FYn13br5FIRERqSE1q+TixYun1Q8iGmOcVSKH0wGJSDmWSuQwcBORchyclMNL3omIAoYZNxEpx4RbDgM3ESnHuwPKYeAmIuUYt+Wwxk1EFDDMuIlIOWaQchi4iUi5CdZKpPCDjogoYJhxE5FyvABHDgM3ESnHSokcBm4iUo41Wzn8exERBQwzbiJSjrNK5DBwE5FyHJyUw8BNRMoxbsthjZuIKGCYcRORciyVyGHgJiLlODgph4GbiJRjxi2HNW4iooBhxk1Eyp2HhDuXywEAotEoDg4OsLS0dOJjhmlzEAzcRKSc6p8uK5fLiEajSCaTAADLspBIJFAsFoc+Zpg2B8VSCRGNvXw+D9M0vcemacKyLAghhj5mmDYHxYybiJTzK+Gu1+s4PDxsWx8KhRAOhzseI4SA4zjQdb1lvaZpsG27bf0gxwCQblMGA/cZqu2uqu6CEpHri6q7oMy4vuayJhoNX9pZXV3FgwcP2tbfu3cP9+/f73iM4zgd10ciEdRqtaGOGaZNGQzcRKReoz1LHsbi4iIWFhba1odC8lXhXgF42GOGabMTBm4iGhnhcLhrSaQbTdM6ru9U6hj0mGHalMHBSSJSbqJx6MsyDDfQdho0NAxjqGOGaVMGAzcRqdc49GcZ0vz8PCzL8h5bloVYLOZlx47jeHOyBz2m3/aTmGg0fBoVkPDNt9+e9SlJIQ5Ojp/XL1yQ2v//vTjw5bz/6GJ06GObL5YRQiCdTnslD9u2MTc3h0ql0hJ4ex0zyPZhMXDTqWPgHj9BDNxBwsFJIlLPp1kl44KBm4iUG3ZgcVwxcBORegzcUjirhIgoYJhxE5F6zLilMHATkXoM3FJYKiEiChhm3ESkXodbsVJ3DNxEpBynA8ph4CYi9Ri4pbDGTUQUMMy4iUi9s79lUqAxcBOReiyVSGHgJiLlODgphzVuIqKAYcZNROox45bCwE1E6jFwS2GphIgoYJhxE5F6zLilMHATkXKcVSKHgZuI1ONNpqSwxk1EFDBtgfvly5cdd1xfX8fu7u6pd4iIxlCj4c8yJrzALYTArVu3cO3aNfzgBz/Ahx9+2BLEY7EY3n33XSWdJKIR1zj0ZxkTXuD+8MMP0Wg08Pnnn6NYLELXdaRSKTx//hwAEI1G0RijTzQiOjsTjUNflnHhDU5aloUvvvgCb731FgBgcnISd+7cQT6fx49//GO8+eabmJiYUNZRIiI64gXuycnJjoE5nU5je3sbz549O9OOEdEYGaNs2Q9eqeTjjz/Gb3/72447xWIxNBoNlkqI6HSwxi3FC9yGYeDjjz/Gl19+2XHHmZkZFIvFM+sYEY2Rw7o/y5homQ548eJF3Lp1q+vO169fP/UOERFRb7xykoiUa/DKSSkM3ESk3hiVOfzAS96JiAKGGTcRqRfAjDuXywE4ujjx4OAAS0tLPfd3HAeFQgHA0ZXqAPDJJ59A0zRvXalUwvT0tPc4EolgZmamrS0GbiJSrlEPVuAul8uIRqNIJpMAji5gTCQSPWfe5fN5ZLNZ73Emk8Hs7Cx2dnYAHAXqzc1NrK+vQ9d1xGKxrh8GLJUQkXqHh/4sZySfz8M0Te+xaZqwLMvLpDspl8uwLMt7nEwmIYSAbdveuo2NDezv72NnZ6dnBs/ATUQjo16v49WrV21L3ceMXggBx3Gg63rLek3TWoLwcdlsFlNTU33btywL1WoVjuN03YeBm4jU8+kCnNXVVUxNTbUtq6urvnW1W0CNRCKo1Wpdj4vH4149GwBKpRJ0XYdhGN66QqEAXddhmiaWl5dRrVY7tsUaNxEp1/BpcHJxcRELCwtt60Oh089Ra7Vazyy5mW3b2N7eRqVS8daZptlSfrl79y5mZ2exv7/fdjwDNxGp51N9OhwOIxwOSx1j2zby+Xzf/bLZLHRdb8mam3Uqn3QihEA+n0elUmlpq1qttswgcduyLKsloAMM3EQ05gzDkLoPkxu8hRAtZQ63rV6EEFhbW/PO5w5mur9/UKlUvDbcskunDwPWuIlIucZh3ZflrMzPz7fMELEsC7FYzAuyjuN487xdQghkMhnE43HYtg3btrG2toZIJALgqAbeHKSr1WpLm80mGgru1frNt9+e9SlJocj1RdVdUKa269+gWJC8fuGC1P5/frzpy3m/M/1TX9oZRPMFOEIIpNNpr/Rh2zbm5uZQqVS8wHvt2rWONXC3hu1eoONe0AOg65RABm46dQzc40c6cP/Xki/n/c6//pkv7Zx3LJUQEQUMByeJSLmgXfKuGgM3EakXwJtMqcRSCRFRwDDjJiL1mHFLYeAmIuX402VyGLiJSD1m3FJY4yYiChhm3ESkHjNuKQzcRKQca9xyGLiJSD1m3FIYuOnUjev9OoDxvU/Ln//4ueoujDQGbiJSjxm3FAZuIlKO9yqRw8BNROpxcFIK53ETEQUMM24iUo81bikM3ESk3Fn+XuQoYKmEiChgmHETkXK8clIOAzcRKdeoM3DLYOAmIuUYuOWwxk1EFDDMuIlIOda45TBwE5FyLJXIYeAmIuUYuOWwxk1EFDDMuIlIuUPeHVAKAzcRKcfBSTkM3ESkHGvccljjJiIKGGbcRKQcM245DNxEpFwQa9y5XA4AEI1GcXBwgKWlpZ77CyFQKpUwPT3tPY5EIpiZmZFuk4GbiEhSuVxGNBpFMpkEAFiWhUQigWKx2PUYIQQ2Nzexvr4OXdcRi8VaArNMmwzcRKTcYcBKJfl8HhsbG95j0zSRSCQghICu612P29jYgGEYJ26Tg5NEpFyjfujLUq/X8erVq7al7uM8cSEEHMdpC6aapsG27b7HW5aFarUKx3GGbpOBm4iU8ytwr66uYmpqqm1ZXV31ra/NAbdZJBJBrVbreWyhUICu6zBNE8vLy6hWq0O1yVIJEY2MxcVFLCwstK0PhU4/R63Val0DMHBU+jBN03t89+5dzM7OYn9/X7pNBm4iUs6vWSXhcBjhcFjqGNu2kc/n++6XzWah6zo0Teu4vVOpo1m1Wm2ZQeLua1lW1+O6tcnATUTKqZzHbRhGz9kgx7nBWwjRNtDYbeARAFKpFCqVirePWwLRdV26zb7fH54+fYqXL1/2fzZEREPyq8Z9Vubn52FZlvfYsizEYjEvO3Ycx5uT7YrH4y3Zc7VabTmmX5vNJhqNRgMAnj9/jnw+j0gkgqWlJTx+/Bi/+MUvABx9Ily/fh0fffSRL0/6m2+/9aUdovMucn1RdReU+PMfP5fa/9n7CV/Oe+lvBs+cT6r5YhkhBNLptFdGsW0bc3NzqFQqLcG8UCh4F9cAaLvAplebzbzAPTs7CwB455138OzZM2xvb8MwDHz++dELIITA06dPcevWrRM/YQZuGhcM3IP5+3/3c1/O+8/+4+98aee882rcz58/xx/+8Ae88cYbAIC9vT1ks1lvR13X8fTp07PvIRGNPN6rRI5X456amvKCNnCUwr/55pstO5fL5bPrGRGNjUa97ssyLrzA/dFHH+HTTz/1Nly/fr1lxydPnuDZs2dn1zMiIurIK5Xouo5f/vKXePnyZUvm7ZqcnPTq3UREfgri3QFVapvH3Slou3pNLiciGhZr3HJ4rxIiooDhlZNEpBwzbjkM3ESkXNDux60aAzcRKcfBSTmscRMRBQwzbiJSjjVuOQzcRKRco95Q3YVAYeAmIuU4OCmHNW4iooBhxk1EyjUOWSqRwcBNRModssYthaUSIqKAYcZNRMpxOqAcBm4iUo7TAeUwcBORcqxxy2GNm4goYJhxE5FyrHHLYeAmIuUOOY9bCgM3ESnHwUk5rHETEQUMM24iUo43mZLDwE1EyrFUIoeBm4iUY+CWwxo3EVHAMOMmIuVY45ajJHC/fuGCitMSnbk///Fz1V0IBN6PWw5LJUREAcNSCREpNw43mRJCQNd1X9pi4CYi5YJ4r5JcLgcAiEajODg4wNLSUs/919bWIIRAPB5vC+CGYUAIgVKphOnpaQBHgT4SiWBmZqatLQZuIlIuaNMBy+UyotEokskkAMCyLCQSCRSLxa7HCCFgWRYsy2pZH4/Hkc1mIYTA5uYm1tfXoes6YrFY1w8DBm4iIkn5fB4bGxveY9M0kUgkepZDdF3H/v5+y7pMJoNsNus93tjYgGEYfc/PwE1EyvlV467X6zg8bC+7hEIhhMNhX84hhIDjOG0BWtM02LbdNXC72bkrl8shnU637WdZFhzHgWma0DStY1ucVUJEyjUOD31ZVldXMTU11basrq761lfHcTquj0QiqNVqXY9rDujVahXT09NtgblQKEDXdZimieXlZVSr1Y5tMeMmIuX8yrgXFxexsLDQtj4UOv0ctVardQ3qzRzHQblcbquHm6YJ0zS9x3fv3sXs7GxbeQVg4CaiERIOh6VLIrZtI5/P990vm81C1/Wu5YtO5ZNOtra2MDk52ba+Wq22zCBx27IsqyWgAwzcRHQOqJxVYhhGz9kgx7nBWwjRNpA4yMBiuVxGPB5vW59KpVCpVLw23LJLpw8D1riJSLlG/dCX5azMz8+3TOuzLAuxWMwLso7jePO8j7Ntu+P64/O7q9VqS5vNJhqNRrAmUBLRyPm9/i99aefH4n/40s4gmi/AEUIgnU57ZRTbtjE3N4dKpdIWeG/evImVlZW27NxxHBQKBe+CHgBd53EzcBORckEM3Cqxxk1EygXtyknVxqLG7TgOMpkMyuUyMpkMhBCqu3RmqtUqEolE1/mgo8q2bczOzuLKlSveFW3jQAiBRCKBa9euYXZ2NjDP+7DR8GUZF2MRuOfm5jAzM4N4PI50Oo3Z2dmB5luOgpmZmbZ7I4w6t1b48ccfo1KpeMFsHJRKJRSLRXz11VcA0HWAjIJt5AO3bduwbdubB6lpGnRdR7lcVtyzs9Nt3umosiwLn332GQzDgGEY3g18Rv3D2nEcbzBL0zS8/fbbiEajajs1oHqj4csyLkY+cO/t7bWN6k5NTY1dFjpOjt8GMxKJQNO0kf8AO/783JkOQVBv+LOMi5EP3LZtt72hL168GJjaH52cZVl4++23VXfjzFiWhdnZWWxtbQUmQWHGLWfkAzeRZVmByTz9YJomVlZWMDU1hVQqpbo7dApGPnDrut5W23zx4kXHewXQ6MnlcshmsyNfJjlO13XvMu5uV+qdJyyVyBn5wG2aZltZRAiBq1evKuoRnZVqtYp33nnHt9/5CyJd1wPx/FkqkTPygdudWeDW+hzHwd7eXsebvNDocOetu9+4hBBYW1tT3KvT15xdCyF63oz/PGHGLWcsrpzc2NhAPp+HEAK2bWNjYyMQb+aTchzH+zWNR48ewTCMQGRfJ2VZVsfarswd4IJICIFUKgVd173EpPlnsWh08F4lRKTcf/qn/8KXdv7qf/9PX9o578Yi4yai822cyhx+YOAmIuUYuOWM/OAkEdGoYcZNRMqN01Q+PzBwE5FyLJXIYamEiChgmHETkXIslchh4CYi5VgqkcPATUTKMeOWwxo3EVHAMOMmIuVYKpHDwE1EyrFUIoeBm4iUO1TdgYBhjZuIKGCYcRORciyVyGHgJiLlODgph4GbiJRjxi2HNW4iooBhxk1EyrFUIoeBm4iUY6lEDkslREQBw4ybiJQLYqnEcRxsbW2hXC6jUqkMdEwulwMARKNRHBwcYGlpSWq7i4GbiJQLWqnEtm1YlgXgKIAPolwuIxqNIplMAgAsy0IikUCxWBxoezOWSohIuXrDn+WsGIaBZDIJXdcHPiafz8M0Te+xaZqwLAtCiIG2N2PGTUQjo16v4/Cw/c4noVAI4XBYQY+OCCHgOE5boNc0DbZtA0DP7cfXM3ATkXK/bfy9L+385je/wYMHD9rW37t3D/fv3/flHMPoVk6JRCKo1Wp9tx/HwE1EI2NxcRELCwtt60Oh81kV7hW0e21n4CaikREOh6VLIrZtI5/P990vm81K1bSbaZrWcb1bHum3/TgGbiIaa4ZhdJy54Sc3OAshYBhG2/n7bT/ufH5/ICIKMMdxvDnZrvn5eW8KIXA03S8Wi3kZdb/tzSYajYBNoCQiUkwIgVKphN3dXdi2jTt37rTMwbZtG3Nzc6hUKi2Bt/kCGyEE0ul0S5mk33YXAzcRUcCwVEJEFDAM3EREAcPATUQUMP8fx/DPHy8mmoQAAAAASUVORK5CYII=",
            "text/plain": [
              "<Figure size 375x375 with 2 Axes>"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "import matplotlib.pyplot as plt\n",
        "import seaborn as sns\n",
        "from tueplots import axes, bundles\n",
        "import numpy as np\n",
        "import torch\n",
        "\n",
        "\n",
        "with torch.no_grad():\n",
        "    feature_cos_sims = cos_sims(toy_model.decoder.weight, toy_model.decoder.weight).cpu()\n",
        "\n",
        "sns.set_theme()\n",
        "plt.rcParams.update({\"figure.dpi\": 150})\n",
        "with plt.rc_context({**bundles.neurips2021(), **axes.lines()}):\n",
        "    plt.figure(figsize=(2.5, 2.5))\n",
        "    sns.heatmap(\n",
        "        feature_cos_sims,\n",
        "        cmap=\"RdBu\",  # Red-Blue diverging colormap\n",
        "        vmin=-1,      # Minimum value\n",
        "        vmax=1,       # Maximum value\n",
        "        center=0,     # Center the colormap at 0\n",
        "        square=True,  # Make cells square\n",
        "    )\n",
        "    plt.title(\"True features cosine similarities\")\n",
        "    plt.show()"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "tCXw-zVHuIpL"
      },
      "source": [
        "## Set up SAE training\n",
        "\n",
        "Here, we set up a training loop to train a SAE using SAELens on our toy features and activations. This is a slightly hacky version of the main `sae_training_runner` in SAELens. We set up the SAE and the toy model to both have the same number of features."
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "1JEndCr8qit-"
      },
      "outputs": [],
      "source": [
        "import torch\n",
        "from torch.nn import init\n",
        "import math\n",
        "from tqdm import tqdm\n",
        "from typing import Literal\n",
        "\n",
        "from sae_lens import LanguageModelSAERunnerConfig\n",
        "from sae_lens.training.sae_trainer import TrainingSAE, SAETrainer\n",
        "from sae_lens.training.training_sae import TrainingSAEConfig\n",
        "from sae_lens.training.geometric_median import compute_geometric_median\n",
        "\n",
        "\n",
        "# We only need a way to get `next_batch()` from the ActivationsStore, but the real\n",
        "# ActivationsStore expects tokens and a LLM rather than toy activations. For our\n",
        "# purposes, this just implements the important interface to use our feature generator\n",
        "class FakeActivationsStore:\n",
        "    def __init__(self, model, generate_batch_fn, batch_size: int):\n",
        "        self.model = model\n",
        "        self.batch_size = batch_size\n",
        "        self.generate_batch_fn = generate_batch_fn\n",
        "        self.estimated_norm_scaling_factor = None\n",
        "\n",
        "    def set_norm_scaling_factor_if_needed(self):\n",
        "        pass\n",
        "\n",
        "    @torch.no_grad()\n",
        "    def next_batch(self):\n",
        "        # the middle param is always 1 in SAELens, I think for legacy reasons\n",
        "        return self.model(self.generate_batch_fn(self.batch_size)).unsqueeze(1)\n",
        "\n",
        "# Ignore saving checkpoints, the toy models train very fast\n",
        "def _save_checkpoint(trainer: SAETrainer, checkpoint_name: int | str, wandb_aliases: list[str] | None = None):\n",
        "    pass\n",
        "\n",
        "# this is copied from SAELens sae_training_runner.py. This should probably not be in the runner\n",
        "def _init_sae_group_b_decs(\n",
        "    sae: TrainingSAE,\n",
        "    cfg: LanguageModelSAERunnerConfig,\n",
        "    store: FakeActivationsStore,\n",
        ") -> None:\n",
        "    if cfg.b_dec_init_method == \"geometric_median\":\n",
        "        layer_acts = store.next_batch().detach()[:, 0, :]\n",
        "        # get geometric median of the activations if we're using those.\n",
        "        median = compute_geometric_median(\n",
        "            layer_acts,\n",
        "            maxiter=100,\n",
        "        ).median\n",
        "        sae.initialize_b_dec_with_precalculated(median)  # type: ignore\n",
        "    elif cfg.b_dec_init_method == \"mean\":\n",
        "        layer_acts = store.next_batch().detach().cpu()[:, 0, :]\n",
        "        sae.initialize_b_dec_with_mean(layer_acts)  # type: ignore\n",
        "\n",
        "def train_toy_sae(\n",
        "    toy_model: ToyModel,\n",
        "    activations_batch_provider: Callable[[int], torch.Tensor],\n",
        "    l1=5e-3,\n",
        "    sae_class: type[TrainingSAE] = TrainingSAE,\n",
        "    custom_init_fn: Callable[[TrainingSAE], None] | None = None,\n",
        "    d_in: int = DEFAULT_D_IN,\n",
        "    d_sae: int = DEFAULT_D_SAE,\n",
        "    architecture: Literal[\"standard\", \"topk\"] = \"standard\",\n",
        "    activation_fn_kwargs: dict[str, Any] | None = None,\n",
        "    training_tokens: int = 10_000_000,\n",
        ") -> TrainingSAE:\n",
        "    tqdm._instances.clear()\n",
        "    cfg = LanguageModelSAERunnerConfig(\n",
        "        architecture=architecture,\n",
        "        activation_fn_kwargs=activation_fn_kwargs, # type: ignore\n",
        "        model_name=\"toy\",\n",
        "        hook_name=\"superposition_hook\",\n",
        "        context_size=500,\n",
        "        train_batch_size_tokens=500,\n",
        "        d_in=d_in,\n",
        "        d_sae=d_sae,\n",
        "        device=str(DEFAULT_DEVICE),\n",
        "        training_tokens=training_tokens,\n",
        "        eval_every_n_wandb_logs=99999999999,\n",
        "        l1_coefficient=l1,\n",
        "        lr=3e-4,\n",
        "        log_to_wandb=False,\n",
        "        normalize_sae_decoder=False,\n",
        "        scale_sparsity_penalty_by_decoder_norm=True,\n",
        "        apply_b_dec_to_input=True,\n",
        "        b_dec_init_method=\"zeros\",\n",
        "    )\n",
        "    assert cfg.d_sae is not None\n",
        "    toy_model.eval()\n",
        "    sae = sae_class(TrainingSAEConfig.from_dict(cfg.get_training_sae_cfg_dict()))\n",
        "    # # using the default nn.Linear layer init rather than the built-in SAELens inits, this seems more consistent\n",
        "    init.kaiming_uniform_(sae.W_dec, a=math.sqrt(5))\n",
        "    init.kaiming_uniform_(sae.W_enc, a=math.sqrt(5))\n",
        "    store = FakeActivationsStore(toy_model, activations_batch_provider, sae.cfg.context_size)\n",
        "    _init_sae_group_b_decs(sae, cfg, store)\n",
        "    if custom_init_fn is not None:\n",
        "        custom_init_fn(sae)\n",
        "    trainer = SAETrainer(\n",
        "        model=toy_model,\n",
        "        sae=sae,\n",
        "        activation_store=store, # type: ignore\n",
        "        cfg=cfg,\n",
        "        save_checkpoint_fn=_save_checkpoint,\n",
        "    )\n",
        "    trainer.fit()\n",
        "    return sae"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "oZfr2ude2HEi"
      },
      "source": [
        "### Plotting helpers\n",
        "\n",
        "Some helpers for plotting feature vs latent cosine similarities and showing features with corresponding SAE activations. You can just run these."
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "B14QyyJD2c52"
      },
      "outputs": [],
      "source": [
        "from rich.jupyter import print as rprint\n",
        "from rich.table import Table\n",
        "from rich.text import Text\n",
        "import matplotlib.pyplot as plt\n",
        "import seaborn as sns\n",
        "from tueplots import axes, bundles\n",
        "\n",
        "\n",
        "def plot_sae_feat_cos_sims(\n",
        "    sae: TrainingSAE,\n",
        "    model: ToyModel,\n",
        "    title_suffix: str,\n",
        "    save_path: str | None = None,\n",
        "    figsize = (3.75, 1.75),\n",
        "):\n",
        "    sns.set_theme()\n",
        "    plt.rcParams.update({\"figure.dpi\": 150})\n",
        "    with plt.rc_context({**bundles.neurips2021(), **axes.lines()}):\n",
        "\n",
        "        # Calculate cosine similarities\n",
        "        dec_cos_sims = cos_sims(sae.W_dec.T, model.decoder.weight)\n",
        "        enc_cos_sims = cos_sims(sae.W_enc, model.decoder.weight)\n",
        "\n",
        "        # Convert to numpy arrays\n",
        "        dec_cos_sims = dec_cos_sims.detach().cpu().numpy()\n",
        "        enc_cos_sims = enc_cos_sims.detach().cpu().numpy()\n",
        "\n",
        "        # Create figure with two subplots\n",
        "        fig, (ax1, ax2) = plt.subplots(1, 2, figsize=figsize)\n",
        "\n",
        "        # Plot encoder heatmap\n",
        "        sns.heatmap(\n",
        "            enc_cos_sims,\n",
        "            ax=ax1,\n",
        "            cmap=\"RdBu\",\n",
        "            vmin=-1,\n",
        "            vmax=1,\n",
        "            cbar=False,\n",
        "            xticklabels=True,\n",
        "            yticklabels=True\n",
        "        )\n",
        "        ax1.set_title(\"SAE encoder\")\n",
        "        ax1.set_xlabel(\"True feature\")\n",
        "        ax1.set_ylabel(\"SAE Latent\")\n",
        "\n",
        "        # Plot decoder heatmap\n",
        "        sns.heatmap(\n",
        "            dec_cos_sims,\n",
        "            ax=ax2,\n",
        "            cmap=\"RdBu\",\n",
        "            vmin=-1,\n",
        "            vmax=1,\n",
        "            cbar_kws={'label': 'cos sim'},\n",
        "            xticklabels=True,\n",
        "            yticklabels=True\n",
        "        )\n",
        "        ax2.set_title(\"SAE decoder\")\n",
        "        ax2.set_xlabel(\"True feature\")\n",
        "        ax2.set_ylabel(\"SAE Latent\")\n",
        "\n",
        "        # Set overall title\n",
        "        plt.suptitle(f\"Cos sim with true features ({title_suffix})\")\n",
        "\n",
        "        if save_path is not None:\n",
        "            plt.savefig(save_path, bbox_inches=\"tight\")\n",
        "\n",
        "        return fig\n",
        "\n",
        "# To display the plot, you would call:\n",
        "# fig = plot_sae_feat_cos_sims(sae, model, title_suffix)\n",
        "# plt.show()\n",
        "\n",
        "def print_sample_feats_and_acts(feats: torch.Tensor, sae: TrainingSAE, model: ToyModel):\n",
        "    feat_mags = feats.float().to(DEFAULT_DEVICE)\n",
        "    latent_acts = sae.encode(model(feats.float().to(DEFAULT_DEVICE)))\n",
        "\n",
        "    table = Table(title=\"Sample feature values and corresponding SAE activations\")\n",
        "\n",
        "    # Add columns\n",
        "    table.add_column(\"True features\", justify=\"center\")\n",
        "    table.add_column(\"SAE Latent acts\", justify=\"center\")\n",
        "\n",
        "    def style_row(row):\n",
        "        text = Text()\n",
        "        for val in row:\n",
        "            style = \"bold\" if val > 1e-4 else \"dim\"\n",
        "            text.append(f\"{val:.2f}\", style=style)\n",
        "            text.append(\"  \")\n",
        "        return text\n",
        "\n",
        "    # Add rows\n",
        "    for row1, row2 in zip(feat_mags, latent_acts):\n",
        "        table.add_row(\n",
        "            style_row(row1),\n",
        "            style_row(row2),\n",
        "        )\n",
        "    rprint(table)"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "z9S9QGJx7S3m"
      },
      "source": [
        "## Training an SAE on fully independent features\n",
        "\n",
        "Let's start by training a SAE to recover 4 features, all fully independent of each other. The SAE should be able to do this near perfectly."
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "FEXppXT1NN0Y",
        "outputId": "0e9425e6-3aa1-4390-e45d-e15a425d40d1"
      },
      "outputs": [
        {
          "name": "stderr",
          "output_type": "stream",
          "text": [
            "Objective value: 392.5182:  15%|█▌        | 15/100 [00:00<00:00, 221.81it/s]\n",
            "/usr/local/lib/python3.11/dist-packages/sae_lens/training/training_sae.py:642: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
            "  out = torch.tensor(origin, dtype=self.dtype, device=self.device)\n",
            "24400| l1_loss: 0.00200 | mse_loss: 0.00001: 100%|█████████▉| 99942400/100000000 [01:12<00:00, 1371076.89it/s]\n"
          ]
        }
      ],
      "source": [
        "from functools import partial\n",
        "\n",
        "feat_probs = torch.tensor([0.25, 0.05, 0.05, 0.05])\n",
        "generate_batch = partial(get_training_batch, firing_probabilities=feat_probs)\n",
        "\n",
        "# NOTE: occasionaly this gets stuck in poor local minima. If this happens, try rerunning and it should converge properly.\n",
        "sae = train_toy_sae(toy_model, generate_batch)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 575
        },
        "id": "cvIj6pXI3LJS",
        "outputId": "9337e8d5-2409-4771-9560-c138cb48f66f"
      },
      "outputs": [
        {
          "data": {
            "image/png": "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",
            "text/plain": [
              "<Figure size 562.5x262.5 with 3 Axes>"
            ]
          },
          "execution_count": 9,
          "metadata": {},
          "output_type": "execute_result"
        },
        {
          "data": {
            "image/png": "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",
            "text/plain": [
              "<Figure size 562.5x262.5 with 3 Axes>"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "plot_sae_feat_cos_sims(sae, toy_model, \"Independent features\")"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "AZB0I7CNStBF"
      },
      "source": [
        "The SAE is able to basically perfectly recover the feature directions here. The encoder correctly filters out each feature, and the decoder perfectly matches the true feature directions."
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 166
        },
        "id": "urE1RR9OR4U5",
        "outputId": "185ab515-f82f-445e-afbf-e4642e1ac2ba"
      },
      "outputs": [
        {
          "data": {
            "text/html": [
              "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"font-style: italic\">Sample feature values and corresponding SAE activations</span>\n",
              "┏━━━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━━━━━━━━━━━━━━━━┓\n",
              "┃<span style=\"font-weight: bold\">      True features       </span>┃<span style=\"font-weight: bold\">     SAE Latent acts      </span>┃\n",
              "┡━━━━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━━━━━━━━━━━━━━━━━━━┩\n",
              "│  <span style=\"font-weight: bold\">1.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  │  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"font-weight: bold\">1.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  │\n",
              "│  <span style=\"font-weight: bold\">1.00</span>  <span style=\"font-weight: bold\">1.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  │  <span style=\"font-weight: bold\">0.99</span>  <span style=\"font-weight: bold\">1.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  │\n",
              "│  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"font-weight: bold\">1.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  │  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"font-weight: bold\">1.00</span>  │\n",
              "│  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"font-weight: bold\">1.00</span>  │  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"font-weight: bold\">1.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  │\n",
              "└──────────────────────────┴──────────────────────────┘\n",
              "</pre>\n"
            ],
            "text/plain": [
              "\u001b[3mSample feature values and corresponding SAE activations\u001b[0m\n",
              "┏━━━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━━━━━━━━━━━━━━━━┓\n",
              "┃\u001b[1m \u001b[0m\u001b[1m     True features      \u001b[0m\u001b[1m \u001b[0m┃\u001b[1m \u001b[0m\u001b[1m    SAE Latent acts     \u001b[0m\u001b[1m \u001b[0m┃\n",
              "┡━━━━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━━━━━━━━━━━━━━━━━━━┩\n",
              "│  \u001b[1m1.00\u001b[0m  \u001b[2m0.00\u001b[0m  \u001b[2m0.00\u001b[0m  \u001b[2m0.00\u001b[0m  │  \u001b[2m0.00\u001b[0m  \u001b[1m1.00\u001b[0m  \u001b[2m0.00\u001b[0m  \u001b[2m0.00\u001b[0m  │\n",
              "│  \u001b[1m1.00\u001b[0m  \u001b[1m1.00\u001b[0m  \u001b[2m0.00\u001b[0m  \u001b[2m0.00\u001b[0m  │  \u001b[1m0.99\u001b[0m  \u001b[1m1.00\u001b[0m  \u001b[2m0.00\u001b[0m  \u001b[2m0.00\u001b[0m  │\n",
              "│  \u001b[2m0.00\u001b[0m  \u001b[2m0.00\u001b[0m  \u001b[1m1.00\u001b[0m  \u001b[2m0.00\u001b[0m  │  \u001b[2m0.00\u001b[0m  \u001b[2m0.00\u001b[0m  \u001b[2m0.00\u001b[0m  \u001b[1m1.00\u001b[0m  │\n",
              "│  \u001b[2m0.00\u001b[0m  \u001b[2m0.00\u001b[0m  \u001b[2m0.00\u001b[0m  \u001b[1m1.00\u001b[0m  │  \u001b[2m0.00\u001b[0m  \u001b[2m0.00\u001b[0m  \u001b[1m1.00\u001b[0m  \u001b[2m0.00\u001b[0m  │\n",
              "└──────────────────────────┴──────────────────────────┘\n"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "# test out feature firing patterns\n",
        "\n",
        "test_feats = torch.tensor([\n",
        "    [1, 0, 0, 0],\n",
        "    [1, 1, 0, 0],\n",
        "    [0, 0, 1, 0],\n",
        "    [0, 0, 0, 1],\n",
        "])\n",
        "\n",
        "print_sample_feats_and_acts(test_feats, sae, toy_model)"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "LzypZt1pSXe-"
      },
      "source": [
        "## Feature co-occurrence leads to feature absorption\n",
        "\n",
        "Here, feature 1 only fires if feature 0 also fires. Otherwise everything is the same as above. Feature 0's base probability is adjusted so it still fires the same proportion of times as in the above example.\n",
        "\n",
        "You can think of this like feature 1 means \"is a square\", and feature 0 means \"is a rectangle\". All squares are rectangles, so everytime the \"is a square\" feature fires the \"is a rectangle\" feature also fires. Co-occurrence like this is extremely common in reality, as any naturally forming hierarchy will have co-occurring features like this."
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "84AWonZf628N",
        "outputId": "0b95afd4-e786-4e40-b74c-b3c05dbf5b22"
      },
      "outputs": [
        {
          "name": "stderr",
          "output_type": "stream",
          "text": [
            "Objective value: 334.4626:  12%|█▏        | 12/100 [00:00<00:00, 865.33it/s]\n",
            "/usr/local/lib/python3.11/dist-packages/sae_lens/training/training_sae.py:642: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
            "  out = torch.tensor(origin, dtype=self.dtype, device=self.device)\n",
            "24400| l1_loss: 0.00175 | mse_loss: 0.00000: 100%|█████████▉| 99942400/100000000 [01:14<00:00, 1337426.48it/s]\n"
          ]
        }
      ],
      "source": [
        "from functools import partial\n",
        "\n",
        "# We modify feature 1's base firing prob to be 4x the value above, since we further restrict\n",
        "# it to only firing if feature 0 fires in `modify_feats()` below. This forces it to\n",
        "# co-occur with feature 0, while keeping its true firing rate the same as before.\n",
        "feat_probs = torch.tensor([0.25, 0.2, 0.05, 0.05])\n",
        "def modify_feats(feats: torch.Tensor):\n",
        "    feat_0_fires = feats[:, 0] == 1\n",
        "    feats[~feat_0_fires, 1] = 0\n",
        "    return feats\n",
        "\n",
        "generate_batch = partial(\n",
        "    get_training_batch,\n",
        "    firing_probabilities=feat_probs,\n",
        "    modify_firing_features=modify_feats,\n",
        ")\n",
        "# NOTE: occasionaly this gets stuck in poor local minima. If this happens, try rerunning and it should converge properly.\n",
        "sae_abs = train_toy_sae(toy_model, generate_batch)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 575
        },
        "id": "_J11pN_X3T2P",
        "outputId": "45054dd2-5f22-40c2-84af-6bca0047efac"
      },
      "outputs": [
        {
          "data": {
            "image/png": "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",
            "text/plain": [
              "<Figure size 562.5x262.5 with 3 Axes>"
            ]
          },
          "execution_count": 12,
          "metadata": {},
          "output_type": "execute_result"
        },
        {
          "data": {
            "image/png": "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",
            "text/plain": [
              "<Figure size 562.5x262.5 with 3 Axes>"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "plot_sae_feat_cos_sims(sae_abs, toy_model, \"feat 1 co-occurs w/feat 0\")"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "nS6BTNnbS7cN"
      },
      "source": [
        "Here we see feature absorption. There's a SAE latent which encodes both feature 0 and feature 1 together in the decoder, but its encoder is only matching feature 1. The latent tracking feature 0 has a decoder which perfectly reconstructs feature 0, but the encoder of this feature is excluding feature 1, making a hole in its firing pattern. Features 2 and 3 are found and reconstructed perfectly, as before."
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 166
        },
        "id": "VoGKRzt6xsd5",
        "outputId": "daee0ec0-7924-42c6-cf4d-59f2aaaaa8ba"
      },
      "outputs": [
        {
          "data": {
            "text/html": [
              "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"font-style: italic\">Sample feature values and corresponding SAE activations</span>\n",
              "┏━━━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━━━━━━━━━━━━━━━━┓\n",
              "┃<span style=\"font-weight: bold\">      True features       </span>┃<span style=\"font-weight: bold\">     SAE Latent acts      </span>┃\n",
              "┡━━━━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━━━━━━━━━━━━━━━━━━━┩\n",
              "│  <span style=\"font-weight: bold\">1.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  │  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"font-weight: bold\">1.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  │\n",
              "│  <span style=\"font-weight: bold\">1.00</span>  <span style=\"font-weight: bold\">1.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  │  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"font-weight: bold\">1.41</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  │\n",
              "│  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"font-weight: bold\">1.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  │  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"font-weight: bold\">1.00</span>  │\n",
              "│  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"font-weight: bold\">1.00</span>  │  <span style=\"font-weight: bold\">1.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  │\n",
              "└──────────────────────────┴──────────────────────────┘\n",
              "</pre>\n"
            ],
            "text/plain": [
              "\u001b[3mSample feature values and corresponding SAE activations\u001b[0m\n",
              "┏━━━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━━━━━━━━━━━━━━━━┓\n",
              "┃\u001b[1m \u001b[0m\u001b[1m     True features      \u001b[0m\u001b[1m \u001b[0m┃\u001b[1m \u001b[0m\u001b[1m    SAE Latent acts     \u001b[0m\u001b[1m \u001b[0m┃\n",
              "┡━━━━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━━━━━━━━━━━━━━━━━━━┩\n",
              "│  \u001b[1m1.00\u001b[0m  \u001b[2m0.00\u001b[0m  \u001b[2m0.00\u001b[0m  \u001b[2m0.00\u001b[0m  │  \u001b[2m0.00\u001b[0m  \u001b[2m0.00\u001b[0m  \u001b[1m1.00\u001b[0m  \u001b[2m0.00\u001b[0m  │\n",
              "│  \u001b[1m1.00\u001b[0m  \u001b[1m1.00\u001b[0m  \u001b[2m0.00\u001b[0m  \u001b[2m0.00\u001b[0m  │  \u001b[2m0.00\u001b[0m  \u001b[1m1.41\u001b[0m  \u001b[2m0.00\u001b[0m  \u001b[2m0.00\u001b[0m  │\n",
              "│  \u001b[2m0.00\u001b[0m  \u001b[2m0.00\u001b[0m  \u001b[1m1.00\u001b[0m  \u001b[2m0.00\u001b[0m  │  \u001b[2m0.00\u001b[0m  \u001b[2m0.00\u001b[0m  \u001b[2m0.00\u001b[0m  \u001b[1m1.00\u001b[0m  │\n",
              "│  \u001b[2m0.00\u001b[0m  \u001b[2m0.00\u001b[0m  \u001b[2m0.00\u001b[0m  \u001b[1m1.00\u001b[0m  │  \u001b[1m1.00\u001b[0m  \u001b[2m0.00\u001b[0m  \u001b[2m0.00\u001b[0m  \u001b[2m0.00\u001b[0m  │\n",
              "└──────────────────────────┴──────────────────────────┘\n"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "# test out feature firing patterns\n",
        "\n",
        "test_feats = torch.tensor([\n",
        "    [1, 0, 0, 0],\n",
        "    [1, 1, 0, 0],\n",
        "    [0, 0, 1, 0],\n",
        "    [0, 0, 0, 1],\n",
        "])\n",
        "\n",
        "print_sample_feats_and_acts(test_feats, sae_abs, toy_model)"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "IYiPl17140hQ"
      },
      "source": [
        "In the table above, we pass in some test features and see the corresponding SAE latent activations. When features 0 and 1 are both active together, only one latent fires, the one corresponding to feature 1, and the latent corresponding to feature 0 doesn't fire even though feature 0 is active! This is classical feature absorption - the latent corresponding to feature 1 \"absorbs\" feature 0."
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "gPQtb73e3lhI"
      },
      "source": [
        "# Magnitude variance causes partial absorption\n",
        "\n",
        "So far each feature fires with magnitude 1.0 always. In a real model, there will be some variance in how strongly features fire. Let's update our feature generation to add some variance to feature 0, while keeping everything else the same from our feature absorption example above."
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "0CITDKJk37d_",
        "outputId": "28188847-c918-4341-d831-52ea2f1aa268"
      },
      "outputs": [
        {
          "name": "stderr",
          "output_type": "stream",
          "text": [
            "Objective value: 348.2523:  14%|█▍        | 14/100 [00:00<00:00, 888.61it/s]\n",
            "/usr/local/lib/python3.11/dist-packages/sae_lens/training/training_sae.py:642: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
            "  out = torch.tensor(origin, dtype=self.dtype, device=self.device)\n",
            "24400| l1_loss: 0.00185 | mse_loss: 0.00000: 100%|█████████▉| 99942400/100000000 [01:16<00:00, 1310367.82it/s]\n"
          ]
        }
      ],
      "source": [
        "from functools import partial\n",
        "\n",
        "# Like in the feature absorption example above, we force feature 1 to only fire if feature 0 also fired.\n",
        "feat_probs = torch.tensor([0.25, 0.2, 0.05, 0.05])\n",
        "# However, we now allow feature 0 to have some variance in its firing pattern,\n",
        "# so the relative magnitudes of feature 0 and feature 1 are no longer fixed\n",
        "std_firing_magnitudes = torch.tensor([0.1, 0.0, 0.0, 0.0])\n",
        "def modify_feats(feats: torch.Tensor):\n",
        "    feat_0_fires = feats[:, 0] == 1\n",
        "    feats[~feat_0_fires, 1] = 0\n",
        "    return feats\n",
        "\n",
        "generate_batch = partial(\n",
        "    get_training_batch,\n",
        "    firing_probabilities=feat_probs,\n",
        "    modify_firing_features=modify_feats,\n",
        "    std_firing_magnitudes=std_firing_magnitudes,\n",
        ")\n",
        "\n",
        "# NOTE: occasionaly this gets stuck in poor local minima. If this happens, try rerunning and it should converge properly.\n",
        "sae_part = train_toy_sae(toy_model, generate_batch)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 575
        },
        "id": "8mt64oXU4VrW",
        "outputId": "b2ba5d50-e367-46ef-de49-64752e6d789b"
      },
      "outputs": [
        {
          "data": {
            "image/png": "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",
            "text/plain": [
              "<Figure size 562.5x262.5 with 3 Axes>"
            ]
          },
          "execution_count": 15,
          "metadata": {},
          "output_type": "execute_result"
        },
        {
          "data": {
            "image/png": "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",
            "text/plain": [
              "<Figure size 562.5x262.5 with 3 Axes>"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "plot_sae_feat_cos_sims(sae_part, toy_model, \"feat 1 co-occurs w/feat 0, feat 0 magnitude varies\")"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "py2Fwfma58GJ"
      },
      "source": [
        "This looks a lot like the original example of feature absorption, with some subtle differences. The latent tracking feature 1 still absorbs feature 0 too, but the cosine sim with feature 0 is less strong that it was in the full absorption example. Let's see what various feature firing patterns look like in SAE activations."
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 166
        },
        "id": "JMepAiSZ6at6",
        "outputId": "f6f7c506-2f8d-49ee-fc7d-489afb24381b"
      },
      "outputs": [
        {
          "data": {
            "text/html": [
              "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"font-style: italic\">Sample feature values and corresponding SAE activations</span>\n",
              "┏━━━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━━━━━━━━━━━━━━━━┓\n",
              "┃<span style=\"font-weight: bold\">      True features       </span>┃<span style=\"font-weight: bold\">     SAE Latent acts      </span>┃\n",
              "┡━━━━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━━━━━━━━━━━━━━━━━━━┩\n",
              "│  <span style=\"font-weight: bold\">1.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  │  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"font-weight: bold\">1.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  │\n",
              "│  <span style=\"font-weight: bold\">1.00</span>  <span style=\"font-weight: bold\">1.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  │  <span style=\"font-weight: bold\">1.26</span>  <span style=\"font-weight: bold\">0.22</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  │\n",
              "│  <span style=\"font-weight: bold\">0.90</span>  <span style=\"font-weight: bold\">1.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  │  <span style=\"font-weight: bold\">1.26</span>  <span style=\"font-weight: bold\">0.12</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  │\n",
              "│  <span style=\"font-weight: bold\">0.75</span>  <span style=\"font-weight: bold\">1.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  │  <span style=\"font-weight: bold\">1.26</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  │\n",
              "└──────────────────────────┴──────────────────────────┘\n",
              "</pre>\n"
            ],
            "text/plain": [
              "\u001b[3mSample feature values and corresponding SAE activations\u001b[0m\n",
              "┏━━━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━━━━━━━━━━━━━━━━┓\n",
              "┃\u001b[1m \u001b[0m\u001b[1m     True features      \u001b[0m\u001b[1m \u001b[0m┃\u001b[1m \u001b[0m\u001b[1m    SAE Latent acts     \u001b[0m\u001b[1m \u001b[0m┃\n",
              "┡━━━━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━━━━━━━━━━━━━━━━━━━┩\n",
              "│  \u001b[1m1.00\u001b[0m  \u001b[2m0.00\u001b[0m  \u001b[2m0.00\u001b[0m  \u001b[2m0.00\u001b[0m  │  \u001b[2m0.00\u001b[0m  \u001b[1m1.00\u001b[0m  \u001b[2m0.00\u001b[0m  \u001b[2m0.00\u001b[0m  │\n",
              "│  \u001b[1m1.00\u001b[0m  \u001b[1m1.00\u001b[0m  \u001b[2m0.00\u001b[0m  \u001b[2m0.00\u001b[0m  │  \u001b[1m1.26\u001b[0m  \u001b[1m0.22\u001b[0m  \u001b[2m0.00\u001b[0m  \u001b[2m0.00\u001b[0m  │\n",
              "│  \u001b[1m0.90\u001b[0m  \u001b[1m1.00\u001b[0m  \u001b[2m0.00\u001b[0m  \u001b[2m0.00\u001b[0m  │  \u001b[1m1.26\u001b[0m  \u001b[1m0.12\u001b[0m  \u001b[2m0.00\u001b[0m  \u001b[2m0.00\u001b[0m  │\n",
              "│  \u001b[1m0.75\u001b[0m  \u001b[1m1.00\u001b[0m  \u001b[2m0.00\u001b[0m  \u001b[2m0.00\u001b[0m  │  \u001b[1m1.26\u001b[0m  \u001b[2m0.00\u001b[0m  \u001b[2m0.00\u001b[0m  \u001b[2m0.00\u001b[0m  │\n",
              "└──────────────────────────┴──────────────────────────┘\n"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "test_feats = torch.tensor([\n",
        "    [1, 0, 0, 0],\n",
        "    [1, 1, 0, 0],\n",
        "    [0.9, 1, 0, 0],\n",
        "    [0.75, 1, 0, 0],\n",
        "])\n",
        "\n",
        "print_sample_feats_and_acts(test_feats, sae_part, toy_model)"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "g_kMBJIG6zVV"
      },
      "source": [
        "### Partial absorption\n",
        "\n",
        "We see that now the SAE latent tracking feature 0 still fires when the true values of features 0 and 1 are both 1.0, but very weakly. However, if the magnitude of feature 0 drops down to 0.75, then the feature 0 latent fully turns off.\n",
        "\n",
        "We call this phenonemon **partial absorption**. In partial absorption, there's co-occurrence between a dense and sparse feature, and the sparse feature absorbs the direction of the dense feature. However, the SAE latent tracking the dense feature still fires when both the dense and sparse feature are active, only very weakly. If the magnitude of the dense feature drops below some threshold, it stops firing entirely.\n",
        "\n",
        "#### Why does partial absorption happen?\n",
        "\n",
        "Feature absorption is an optimal strategy for minimizing the L1 loss and maximizing sparsity. However, when a SAE absorbs one latent into another, the absorbing latent loses the ability to modulate the magnitudes of the underlying features relative to each other. The SAE can address this by firing the latent tracking the dense feature as a \"correction\" to add back some of the dense feature direction into the reconstruction. Since the dense feature latent is firing weakly, it still has lower L1 loss than if the SAE fully separated out the features into their own latents."
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "3P-UIOrpVIVA"
      },
      "source": [
        "# Imperfect co-occurrence can still lead to partial absorption\n",
        "\n",
        "Next, let's test what will happen if feature 1 is more likely to fire if feature 0 is active, but can still fire without feature 0. We set up feature 1 to fire with feature 0 95% of the time, but 5% of the time it can fire on its own."
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "seFtv1erVdpf",
        "outputId": "faa699aa-ec96-4100-c469-e668c4aeadbf"
      },
      "outputs": [
        {
          "name": "stderr",
          "output_type": "stream",
          "text": [
            "Objective value: 360.8776:  14%|█▍        | 14/100 [00:00<00:00, 849.54it/s]\n",
            "/usr/local/lib/python3.11/dist-packages/sae_lens/training/training_sae.py:642: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
            "  out = torch.tensor(origin, dtype=self.dtype, device=self.device)\n",
            "24400| l1_loss: 0.00187 | mse_loss: 0.00000: 100%|█████████▉| 99942400/100000000 [01:18<00:00, 1277281.60it/s]\n"
          ]
        }
      ],
      "source": [
        "from functools import partial\n",
        "\n",
        "# Here, 95% of the time that feat 1 fires feat 0 also fires, but the other 5% of the time\n",
        "# it fires feat 0 doesn't fire. We keep the overall firing rate of feat 1 at 0.05, but this\n",
        "# means it's strongly correlated with feat 0 but not perfectly co-occurring\n",
        "feat_probs = torch.tensor([0.25, 0.19, 0.05, 0.05])\n",
        "def imperfect_correlation(feats: torch.Tensor):\n",
        "    feat_0_fires = feats[:, 0] == 1\n",
        "     # If feat 0 doesn't fire, feat 1 fires with this prob\n",
        "     # This will keep the overall firing rate at 0.05 for feat 1\n",
        "    feat_1_cond_prob = 0.0003333333\n",
        "    feat_1_cond_fires = torch.bernoulli(feat_1_cond_prob * torch.ones_like(feat_0_fires)) == 1\n",
        "\n",
        "    # if feat 0 doesn't fire, fire feat1 according to the cond prob\n",
        "    feats[(~feat_0_fires * ~feat_1_cond_fires), 1] = 0\n",
        "    feats[(~feat_0_fires * feat_1_cond_fires), 1] = 1\n",
        "    return feats\n",
        "\n",
        "generate_batch = partial(\n",
        "    get_training_batch,\n",
        "    firing_probabilities=feat_probs,\n",
        "    modify_firing_features=imperfect_correlation,\n",
        ")\n",
        "# NOTE: occasionaly this gets stuck in poor local minima. If this happens, try rerunning and it should converge properly.\n",
        "sae_corr = train_toy_sae(toy_model, generate_batch)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 575
        },
        "id": "vx_5ZoB3Y0BP",
        "outputId": "2b102d11-1b49-44cc-bd96-6e406594a3c5"
      },
      "outputs": [
        {
          "data": {
            "image/png": "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LzoamDk/Pw+3243bt28DAHw+HxRFwf3795sOPBUEQR+oefTo0ZpBm62Ut3vw682bN1EoFJDNZjE3NwdBEPR9RVHc16DQZuenk+MmshJj2RhjmczCnqUDKplMdnRxVRQFpVIJoVAIqqrq29mzZ1EoFLpWniAIEARB/zZqtt3nx+zjJjILY9kYY5nMwJ6lA6rd7nqNdkFLJBJ188J0esFutbx8Po/79++jXC6jUqlYOsh09/kx+7iJzMJYNsZYJjMwWTqgOr0oDA8PAwDW19dNmf+k1fLC4TA2NzcxOzuLS5cuQRRFTExM7Lv+ZnafH7OPm8gsjGVjjGUyA2/DUZ2d3/J2D3h0u90QBAHZbNaUulopT1VVyLKMGzduIBKJ6D/TjFF3vtGx7bedRL2GsdxZO4l2Y88S6bSLVi6Xw9TUFDY3N5FKper2u3HjBmKxGLa3t/UlFzY2NlAul7G8vNx2vXuVp7UrnU7r7cxkMg277gVBgCRJEEURsiwjEolAFMWWj20/7STqFYzl/bWTaDf2LJFuamoKbrcbiUQCwWAQ+Xwei4uLdd/+AoEAVldXoSgKYrEYYrEYyuVy3VMurWqlvMXFRf39RCIBn88Hv99f140+OzsLRVEwPz+PZ8+etX1s+20nUS9gLO+/nUQ7uarVatXuRhARERH1KvYsERERERlgskRERERkgMkSERERkQEmS0REREQGmCwRERERGWCyRERERGSAyRIRERGRASZLRERERAaYLBEREREZYLJEREREZIDJEhEREZEBJktEREREBpgsERERERlgskRERERkgMkSERERkQEmS0REREQGmCwRERERGfh/tMQAcZwGRRIAAAAASUVORK5CYII=",
            "text/plain": [
              "<Figure size 562.5x262.5 with 3 Axes>"
            ]
          },
          "execution_count": 18,
          "metadata": {},
          "output_type": "execute_result"
        },
        {
          "data": {
            "image/png": "iVBORw0KGgoAAAANSUhEUgAAAm4AAAEXCAYAAAAUbciHAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjAsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvlHJYcgAAAAlwSFlzAAAXEgAAFxIBZ5/SUgAANDNJREFUeJzt3W9sG2eeH/AvrezeLhCNfLg3bddjtPtCikX5xQFWEtIHtF0pJuV3ZjZigL4xbVEJsjGZO1M4FGsxMe1FAYvJRb7c4iIq1t2LYkV5V/tqTVJW0haFhof1i76QRl73zaEe7bVA35gjo7uNY7Mv1JkVxT8akkPOPOL3AxCwydHMb0b6PfPjM8/M4ymXy2UQERERkesdczoAIiIiIrKGhRsRERGRIFi4EREREQmChRsRERGRIFi4EREREQmChRsRERGRIFi4EREREQmChRsRERGRIFi4EREREQmChRsRERGRIFi4EREREQmChRsRERGRIFi4EREREQmChRsRtSWTyWB8fBy6rjsdChG5mK7riMViTofRFfl8HqOjo9A0zfZ121q4aZqGZDKJ8fFxDA0NYXR0FOPj44jFYsjn83ZuilqkaRqGhoaQyWScDsVxRiMyOjqKoaGhnmlQ7JTP55FOp7G0tARJkqo+5zE+Gmq1G2xLqFm5XA7Hjx+vev8othPBYBDT09MIhUK2f6m1rXAzvnVns1kMDw8jkUhgcnISw8PDKBQKWFhYsGtTHZHP54X7gxExZjcZGxvD9vY2pqenkUqlcPr0aadDEoqu65idncXU1BRkWa65jIjHOJ/PH7mcYltBbpDNZhEOh6veF62dyGazZgfV+Ph43S8v0WgUAwMDiMfjtm7/JTtWkslkkE6nIcsylpaWqhpxXdextbVlx6aIbJHJZKDrOr788suaPUV0uHQ6DV3XMTMzU/NzkY5xPp/H5uYmisUiVFVFIBBwOiSiI0XXdei6Dq/XW/G+SO0EAMzNzWFxcRF+vx/hcBibm5tIp9PY3NzE7du3q5ZPJBKIx+NQFAV+v9+WGNou3DRNQzqdhiRJWF1drXngJUmyLeBOCQaDePTokdNhNKVezLFYDMViEQ8ePOhKHN3enh02Nzchy3LXGgoRj1Ejuq7X/fZsEOkYx+NxyLKM4eFhqKrageg6r9H+i9i+0dFSr70QqZ3QNA2Li4sIh8NIpVLm+0bnVa3iLBgMQpIkZDIZ2+qgti+VJpNJAHtVpQjVMhEA7O7uOh2C0BRFAbDXKNUj0jF+9OgR1tfXcfPmTadDITqSstlszfZCpHbCGKufSCQq3o9Go2ZxVsvExAQURbFtrFtbhZumaVAUBZIkNfzmTURHi1G4ub0nnYicp6oqJEmqOxZWFLlcrm7v4MjIiNkuHmS0k/U+b1ZbhZtxSWFkZKSln89kMgiFQhgaGkIoFMLc3FzVMgfvNhkdHUUsFmvqAFhZR727psbHx5HP56Eoihnr/sGImqaZ6x4fHzd7IK2Ym5vD0NBQ1e3CxkDiWtX7+Pg4QqFQzZiTySSGhoZQKBSg6zqGhobMVy2KoiASiZixZ7NZy7Fb3d7+Y6jrOpLJJEZHR81jb+xDrd/90NAQIpFIzW3Pzc2Zg0MjkYjlv4dsNouhoSEoimJue2hoqGrfraw/n8+bx290dBSRSKTqd2n1GDVzDA47plbibzevFEWpGqticOMx7hZN0xCJRJDP56GqakXs9doGK/vY6HfezN/YwTbFyratymQy5u+9ltHRUbPtsiqbzSISiZh/o8axrbXtw84lVveh2fVYjfGw5exuB1rN8XbPS7Xcu3evqnNHxHZCVdW6xafxfq1eNaOt3NzctLytRtrucQOA4eHhpn82EokgnU5jZGQEqVQKPp8Pi4uLVc+DCoVCKBaLSCQSmJ+fx/T0NHZ2drCxsWF5W+2sQ9M0ZLNZJJNJTExMYGpqCqVSCel0GnNzc4hEIpBlGdPT0wD2/hitNhrnz58HgKokv3fvHiRJQi6Xq4pF0zRMTEzUXF80GsXS0hK8Xi8kScLS0pL5OiiXyyGZTMLv92NychKlUgnJZLKpx7ZY3Z6madjc3EQoFEIul4PP52vrm1coFMLi4iICgYA5ziASiVgam+T3+ytuoDHi3X9MraxfVVXE43H09/djenoaiUTCbEj3NxjN/E6a0eiYWom/3bzSNA0nTpyo+dlROcatUhQFs7OziMfjGB4eNvc7m81W3dVpdR+B+r/zVve/mW1bYZyYa53YjctEzVyZicViZrE7NTWFyclJAHvjEfefI6yeSw7Tynqsxmh1uWYd1g60kuN2n5cAoFAoVH0uajvR39/f8P1SqVT1mbGP29vbTW2rrnIbFhYWyoODg+Vbt2419XO3bt0qDw4Oljc2Niref/z4cXlwcLB85cqViv8vLy+3HKPVdRjLLSwsVL03ODhYLpVK5vtbW1vm+wf3YXBwsDw2NmY5vjNnzpQvXrxYtQ7jGO3frnG8Hz9+XDfmcrlcvnjxYvnMmTMN97PePhnHvhlWt3fx4sWKbe7/vNbfkPEz+xnHYGtrq+L9K1eulC9cuNB2zFbXXyqVzN/DwX2pdQytHCOrx6DRMbUSf7t5VSqVyoODg+XZ2dmGy7npGFtl7FsrebA/voN/i6VSqTw2Nla131b38bA8Kpet/Y3tbyuaOb6N2sf97125cqWijTr4vlXLy8s12zZjuwar55LDtLIeqzFaXc7OdqDdHG/nvHTQxsZGw9+DSO1Eo78p49gcjNdw5syZps5RjbTV42Z0/zVbRRoV9MHxMbIsY2pqCoVCAZqmYWBgAMDeN9VW7/SyYx1+v7/imrax37XulvV6vU19Wz04aNHoBn7nnXcAoOLbjaIokGXZlnEC9fapUwNFJUnC/Px82zewLCwsIBAIVF2mm5mZgaqqbQ/+tLr+WuM1jLEPtn2rOkStY2ol/nZzwvj7rvfN8zAiHeNWHRw+IkmSOaD53r17Fe83s4925VEr27bCaLeWl5fN93RdR6FQaKq3zXi8VDQarfpsf8xWzyWHaWU9VmO0ulyrav1NtJvjdp6XlpeXzV68Zri1nTjsHNkoN11xc4LRODXzjDbjj6jeA/aM943BjIlEAqqqIhQKmdeumxnfZsc6Drum3Q7jLhsjnnw+b3bl+v3+iu5qRVFse75UtweJ+ny+tk82xnOACoVCxfgEY9whgJbH59ixfqMoqtVV3gkHj6nV+O3IiVaJdoztZBQFh/2NNtpHO/Ko1W1b4fV64fV6sbKyYr5nnOStFm7G38hhN740cy5RVRWKolS9ml1PszFaXa4dtf4m2s1xO89LxWKx4d3ntbi5nai3zsMKOjvjaes5bsYvUVGUQ5/pZDACf/LkiaXlotEogsGgeYOA8UokEjW/wdTS7jrq9SwY32rasf9uk2AwCEVRzOMYDAbNcRFGorTyzaWWVntLWmVHoWj8TUxNTdU9DvUGzHdi/aqqIpvNmoNrDd16LM7BY9pM/O3kRDv7J9ox7oZm9tHuL1ydOL7hcBjJZNJ8plU2mzULOjs1cy5ZWFio2fO0vr7e9DnJber9TbST43adl/L5fMOxb/W4tZ1odEXN6MCq9/solUq21AyADc9xMwYMGk9RP4zxB1GvC9Oo8Pdfatg/APfRo0fwer1NT6Flxzo6xe/3I5fLmYM8jWNk/MErimIODLW78euWWvPTNcvo/tY0zTwRHHx1a/3G3WfAXg6sr6/j0aNHXe3JPHhMmz0+reaE0fi0clldtGNsJ6Nt29+z0+w+2pFHrW7bqnA4DEmSsLy8DF3XoapqU5dJJUmCJEmH9g41cy5ZXV3Fo0ePql6yLLd0TrIao9Xl2tHob6Kd854d5yWrHTq14nZjO+Hz+aDres3i7bAZV3Rdt62QbLtwk2UZiUQCuq4jFArVrUb332kUDoehKErVXStG1bz/F1OrGKx3N1s9dqyjk4LBIHRdx/LyckUSGNfuNzY2UCwW4fP5LK2vv7/f9kltO729g0VAvbtbJycnUSgUajaE7VwmbXb96XTavNPJ7/ebjUS9b+VWjpHVY9CI1fjbyQmj8Wn1eDt5jLvl4PARY15XoPKhxc3uYyPN7r+d2z5ocnISxWKx6cukhunpafOO/oP2j29q5lzSSCvrsRqj1eUMdrQDQPvnvXbPS0aB0+oXaje2E0bv38EnRxj1Tb3eQWN7dtUdtsxVGo1GIcsy4vE4xsfHEQgEzG+Vxvx/xq3gkiQhlUpha2sL8XjcXNb4wzYGWgJ/eM6Y3+/H8PAwTp48CVVVmxroasc6Om1iYgLJZBIrKytV3cqBQMB87ozVy6SnT59GoVBAJBLB8PAwCoUC5ufnO9Zb1872jCTL5XLmDRNGY1nLzMwMtre3EYlEEA6H4fV6oeu6eRngwYMHbX2rsbp+v9+PQqGAZDJpLpPL5ep+q2p0jJo9Bu3Gv7W11XZOeL3elucfduIYH2b/s68AYGdnx3yvlRuCjLFF4XAYjx8/xsrKCnRdRyKRqFhXs/vYSLP7b+e2D3r77bexuLiIbDbb0rjcaDRqPqMun8/D7/fjyZMn5lyyq6ur8Hq9ls8lh2llPVZjtLqcne2AHee9ds9LuVyurTHZbmwnvF4vpqamsLi4iFgshrNnz5q/I7/fX3csn1Fonj17tuXjsZ8thRuwV52vr68jk8lAURQUCgUAe43e5OQk3nnnnYqDuLq6ikwmg1wuh0KhYB6Q/RNW+/1+pFIp5PN5864eo4fP6vg2O9bRaca3GVVVq37x58+fx+LiIoDG0wvtFw6HkcvloCgKSqUSAoFARy8vtbu9VCqFdDqNeDwOr9cLn8+H9fV1M7EOWlpaMv92stmsOcdkvblym2Vl/fPz84jH42bDPjIygunp6aoxFobDjlGzx6Cd+O3ICZ/PZ/YWtHLMnTjGjSSTyYp1Gg/PBdBSWxEOh+H3+82xVV6vF9PT01U53Ow+HrbNZvbfzm0fZFyCVBQFN27caGkdS0tLyGazyGaz5nzYxmXP/SdZK+cSK1pZj9UYrS5nVztgR463e17KZrOWC+d63NZOAHsF5cmTJ5HJZFAoFCwdV7tnmvGUy+WyLWsiop5h9CilUinX9Fy7gfHgz4OTUPeiTCaDbDaL9fV1p0OhLtM0DfF4HKurq06H4grGMLJWJravpe0xbkTUe4xLO61cxqHe0OrAdBLf8vIyf/f/n6ZpUFXVnF3JDizciKglxnOiWn2wNR1dqqpC0zSevHtUrSmuelUmk4EkSbbmAgs3ImpJMBiE3+8375ak3qbrujnGeXZ2FlNTU0fqeXtkjTERO3/3f5jr/MaNG7YeDxZuRNSy+fl56LpedXs89aaFhQVEIhEMDAw0fXMAHQ28RP4Hxh2xzc4ccRjenEBEbdF13Wys+S2bqLcZd1H3OuOu1k4UsSzciIiIiATBS6VEREREgmDhRkRERCQIFm5EREREgmDhRkRERCQIFm5EREREgmDhRkRERCQIFm5EREREgmDhRkRERCQIFm5EREREgmDhRkRERCQIFm5EREREgmDhRkRERCQIFm49Ttd1JJNJjI+PY2hoCOPj44jFYlBVteHPxWIxDA0NIZPJ1F1GVVWMjo42fGWzWbt3yTGapmFoaAj5fN7pUKgHiZrLbswbN8ZEZHjJ6QDIObquY2xsDAMDAwiHw5BlGZubmygUCpidncXq6mrdnysUCpBlGdlsFtFotOE2/H4/wuFwzc+9Xq8t+0LUy5jLRL2DhVsPu3btGgBgdXUVkiQBAILBIGZmZhp+S8/lcvB6vQiHw0gmk1BVtWGjPTw8jGAwaG/wRGRiLhP1Dl4q7WHFYhEjIyNmQ79fo8Y7k8lgYmICExMTAHCkLncSiYi5TNQ7WLj1sJGRESiKAkVRLP+MqqrQNA3hcBiSJMHv93elsVdVFZFIBENDQwiFQlUxZzIZjI+PQ9M0c7nx8fGaY1Q0TUMsFjPH5oRCoarljO2Njo5ifHwcc3NzVesxtjk6OtpwLNFhsWezWYyPj5vrrLUMUSMi5bJdeQMwl6k3sXDrYalUCpIkIRKJmA3aYY1MNpuF3+83v9kb410aDeLVNA2qqla9NE2zFKeqqgiFQujv78fS0hJ8Ph8ikUhV42oUbeFwGPPz8wCAeDwOXdcr1jU+Po7d3V0kEgncuHEDIyMjFScsRVEQCoUgyzLm5+cRjUZRKBQQCoUqjkM6nTaXOXv2LNLpdEux67qOUqmEWCyGhYUFjIyMYGRkxNKxIQLEyWU784a5TD2rTD2tVCqVZ2dny2fOnCkPDg6WBwcHy2NjY+Wtra2ay585c6a8vLxc8d7g4GD54sWLVctubW2Z66z1GhsbsxTjhQsXyhcuXKh478qVK+Vbt26Z/19YWCgPDg5WxLaxsVEeHBws53I5872xsbGqddXax9nZ2Yr3SqVSeXBwsLywsGAuc3A9xv7u314zsY+NjZVLpVLD2IjqESGX7cwb5jL1Kva49ThJkpBKpfDgwQOsr69jamoKmqbh4sWLFT1VwN43cV3XzfEwhkAgAEVR6n7rnpqawqNHj6pe6+vrh8ZnfMMPh8PQdd18nT9/HoVCoWp5v99v/luW5ap1aZqG6enputtTFAW6rlfdOWdcSsrlclBVteYy7cZu9JoQtcLtuWxn3jCXqZfxrlIyybKMmZkZnD59GvF4HLlcrqJBMy5BjI6O1vz55eVlzMzM2BqTcQJJJpNIJpMVn9VqGA8Wa7XW1ahBbbSMLMtQFAWlUunQbbUSOy+pkF3cmMt25g1zmXoZCzeqYvRa7f+WrmkaFEXB/Px8Ra+WYWxsDCsrK7Y39gMDAwCA9fX1QxvXwxg/f7D3odYymqbV7LGTZdmMqdF6gOZj5zd0spsbc9mOvGEuUy/jpdIeNjc3V7PByuVyACovOy4vL0OSJASDQUiSVPWanJyEruu230Hl9XohSRKWl5fbXpcsy5BlGQsLC3WXMR6pcHB7xskuEAiYMR28A+/g5SU7YydqRKRctiNvmMvUy9jj1qN0Xcfi4iIWFxcRCAQgyzJOnjyJjY0NFAoFhMPhiuc/raysYHJysu763n77bSwuLmJ5ebnqW/z29nbdxwzIslzzW/9+N27cQDwex+7urvnwz42NDWxvb2NpacnqLgPYG3sSiUTMu08BmI9RWF9fhyRJ5vZisRjOnz+PUqlk3nVm9EJMT08jnU4jFovh7bffhqZpNe9EszN2olpEymU784a5TD3L6bsjyDmlUql869at8oULF8y7wy5cuFBxJ1W5/Ie7Mx8/ftxwfcZ6jLupDrsTbXBwsHzlyhVLsW5tbZUvXrxYPnPmTPnMmTPlixcvljc2NszPjbu59nv8+HHVnWFW1nVwmbGxsYo7x/Zv01jHlStXyhsbG+ULFy40XJfV2ImaIVIu25U3rSzDXKajwFMul8tOF49EREREdDiOcSMiIiISBAs3IiIiIkGwcCMiIiISBAs3IiIiIkGwcCMiIiISBAs3IiIiIkGwcCMiIqKu0HUd2WwWoVDI6VCExZkTiIiIqONUVTWnUjtsfliqj4UbERERdZzX64XX60U+n3c6FKGxcCMiIiLLnj9/jhcvXlS9f+zYMfT19TkQUW9h4dZhv/v9750OoSkeAWdAu/7VPzodQtOSY993OoSmffc733E6BEf9/ne/czqEniD5f+R0CE3Rlb9xOoSmfee73z10mW//6aW6n3186U/x2WefVb3//vvv48qVK23FRodj4UZEREQVjr307bqfvffee3j33Xerf+YY73fsBhZuREREVMFzrP4lz76+Pl4SdRALNyIiIqpw7Fv1e9zIWSzciIiIqEJfg0ul5CwWbkRERFTh2Evfsn2dmqZheXkZxWIRmqZhbm4Ox48fRzQatX1bRxkLNyIiIqrQ6OaEVsmyjJmZGdvX22tYuBEREVEFjnFzLxZuREREVKETPW5kDxZuREREVOFYg8eBkLNYuBEREVEF9ri5Fws3IiIiqsDCzb1YuBEREVEF3pzgXizciIiIqAJ73NyLhRsRERFV6HuJ5YFb8TdDREREFTzHPE6HQHX0bOG2traGX/3qV1hbW6t43+/34+2338Ybb7zhUGRE1CzmM5G9+vqOOR0C1dGThdvKygrS6TSmp6dx/vx5yLIMACiVStja2sKPf/xjPHnyBG+99ZbDkRLRYZjPRPY79hILN7fqycJtcXERf/d3f4fh4eGqz3w+H4LBIH74wx+yoScSAPOZyH7scXOvnizcnjx5gpMnT9b9/Pjx4yiXy12MiIhaxXwmsl8fe9xcqyd/M6+//jri8Th++9vfVn22s7ODDz74AH6/34HIiKhZzGci+x3r89R9kbN6ssft9u3biMViGBsbg8fjgSRJAABd1wEAgUAAN27ccDJEIrKI+UxkP/a4uVdPFm7AXmMPAIqiYGdnBwAgyzJGRkbQ39/vZGhE1CTmM5G9+DgQ9xK6cDMa6BMnTrS8Dl5CIXKeHbkMMJ+J7MKbE9zL9b+ZU6dOmY36QQsLC0in012OiIhawVwmEkffS8fqvshZrv8NNLob7OzZsygWi12MhohaxVwmEgdvTnAvV14q3dnZwfb2tvn/tbW1qksomqYhm82aA5CJyH2Yy0RiYs+ae7mycFNVFfF4HADg8Xhw69atmstJkoSrV692MzQiagJzmUhMHOPmXq4s3AKBAH7zm98AAF555RX88pe/xKlTpxyOioiaxVwmEtNL7HFzLVcWbvsFAgFz7kEiEhdzmUgcfXwciGu5vnCbn593OgQisgFzmUgc32aPm2u5vnADgKdPn0JRlLqfnzt3rovREFGrmMtEYvgjFm6u5frCrVAo4IMPPgBQ+3ECHo8HDx8+7HJURNQs5jKRONjj5l6uL9zS6TROnDiBVCrV9lPVicg5zGUicXz7pT6nQ6A6XF+4aZqG27dvw+fzOR0KEbWBuUwkDva4uZfrCzfR5x70NHhavBuVPeLdSZQc+77TITTtJ//pH50OoWk3J9p7jIfouSwiEfNZV/7G6RCaIvl/5HQITfv6v905dJlv8zluruX6wu369eu4fPkySqUSfD4fL7EQCYq5TCQOPg7EvVxfuF26dAmapiGZTNb83OPxVEypQ0TuxFwmEgfvKnUv1xdu4XDY6RCIyAbMZSJxcIybe7m+cJuamnI6BCKyAXOZSBws3NzL9YUbERERdRcLN/cS4jfz8OFDfPzxx3jjjTfw2muvme9fvnwZxWLRwciIqBnMZSIxfPulY3Vf5CzX97gVi0VEIhEEg0FcvXoVf/7nf25+durUKSwuLvK5UEQCYC4TieMo31V69+5dbGxs1PzM4/Hgr/7qr7ocUXNcX7il02lMTU0hkUhgd3e34rOzZ8/i7t27DkVGRM1gLhOJ41vHjmbPWjKZxMrKCgBAluWqzz0CPPvQ9YWbqqpIJBJOh0FEbWIuE4njW33uL2Bakc/nEQwG8emnnzodSstcX1L7fD6zOj4ol8thZGSkyxERUSuYy0Ti+NaxY3VfohP90USu73FLJBJ48803oWmaebB/+9vf4mc/+xnu3r2L1dVVhyMkIiuYy0TiOKo9bsFgEIqiCD2e1lMuu38yTVVVMTs7az5V3ePxoL+/Hzdu3EAgEHA4usZ+/7vfOR1CU0Sc21BEvThXKcBc7jYR81m0+Z2P6lylv9j8p7qfvXn6X9gZTteFQiH88R//MYaHh3Hy5EkMDAxUfH7u3DmHIrPG9T1uAOD1erG6ugpN07Czs4OBgQEMDw87HRYRNYm5TCSGbx3RSeZXVlbML4617iz1eDx4+PBht8NqihCFm0GW5Yq7QHZ2dgCAk1UTCYa5TORuxwTsrbUik8ng5MmTuH79urDtjesLt1OnTuH+/fs1D/DCwgJ0XRf67hCiXsFcJhLHt47oc9w0TcPt27eFHuPm+r7QRkPwzp4927GnrX/88ccdWS9Rr3IqlwHmM1GzvtXnqfsSmd/vdzqEtrmyx21nZ8e8Bg0Aa2trVd/SNU1DNpuFrusdiWFlZQVXr17tyLqJeoUbchlgPhM16yg89qOW69ev4/LlyyiVSvD5fEJeLnVl4aaqKuLxOIC9gYK3bt2quZwkSS01xslk8tCTRCdPIkS9otO5DDCfiTpB9J61ei5dugRN05BMJmt+7vF4Kr5supErC7dAIIDf/OY3AIBXXnkFv/zlL3HqVPuPIjDIsoxMJiP0NW4iEXQ6lwHmM1EnHNUeN9Efvgu4tHDbLxAI1JxPrB3BYBC5XA7z8/N1l3n11Vdt3SZRr+tELgPMZ6JOOKo9blNTU06H0DbXF26NGuNWybJ86PQ6k5OTtm+XqJd1IpcB5jNRJxzRp4EcCULMnLCzs4NsNgtN06o+k2XZ1YOORXvauohPWhdRr86cwFzuLhHzmTMndJ6VmRO2/1f9caHD/0yyM5yOOarPh3R9j1uxWEQkEgGwN4B5d3cX/f39AIDd3V3XT5NDRHuYy0TiOAoTJ8RiMTx8+LBiJoRXXnkFngZfaHhzgg3m5uYQCARw8+ZN9Pf349VXX8VXX32Fl19+GZcuXcLp06edDpGILGAuE4mjT8De2oMmJiaqhlFcvXq1YeEmAtcXbtvb2/jJT35ifjMfGBjAzs4OXnnlFUSjUXz44Ye4fPmyw1ES0WGYy0TiOAr3JkSjUUvvicb1naGyLJvXqQFgeHjYnBhW1/WaY2WIyH2Yy0Ti6DvmqfsSWbFYxNramvn/p0+f4oMPPsC5c+fw0UcfORdYE1xfuPl8PvzqV78y/z8xMYGFhQWsra3h888/hySJMUiSqNcxl4nE0efx1H2JLJPJYHNz0/z/hQsXUCwW8frrr+PevXtCFG+uL9yi0WjFNepgMIjh4WHEYjFsb28jlUo5GB0RWcVcJhLHMU/9l8i2trbM8bTFYhGapiGRSCCVSuHq1avI5XIOR3g4149xk2W56oF5S0tLFXekEZH7MZeJxHEUxrjVouu6+SDwjY0NeDweTExMAABOnjwpxPR4ru9xq6e/vx+apuHDDz90OhQiagNzmch9juoYt+HhYeRyOTx9+hSFQgGyLOPll18GsDe3cidmd7GbsIUbsPdwvZWVFafDIKI2MZeJ3KXPU//Vrrm5OczNzSGTyWBubq79FTYhkUhgYWEBo6Oj0DQN169fNz/LZrNCPE/S9ZdKiYiIqLs61bOWzWZx/Phx87EciqIgEolgaWmpI9s7yO/348GDB9ja2sLIyEjFMI1EIoHh4eGuxNEOoXvciIiIyH6N7ip9/vw5nj17VvV6/vz5oetNp9Pw+/3m//1+PxRF6erjgPr7++Hz+arG1gYCASEulbLHrcM+VsR6NtVfDj1zOoSmffMn33c6hKb9+N/+K6dDoCaJOCdlqfhTp0M48o7qMT6G+nPG/vSnP8Vnn31W9f7777+PK1eu1P05TdMqbg4wSJIkzPgyN2DhRkRERJXKL+p+9N577+Hdd9+tev/YscYX8erdsTkwMIBSqdRcfD3MdYXbxx9/bHlZPmmdyL2Yy0Ti8rz4pu5nfX196Ovrs21bpVJJiMdwuIXrCrdMJtPU8qJPFkt0VDGXiQT24vDxas2qNztKrcunVJ/rCrfV1VWnQyAiGzCXicTVqMetVbIsQ5IkaJoGr9db8dnB/1N9rivcRLgVl4gOx1wmElgHCjcAmJ6ehqIoZqGmKEpX7+YsFovY3d3FuXPnAOxNMn/t2jVsb2/D7/cLMVep6wo3IiIicpbneWcKt2g0aj6A9/jx49A0DTdv3uzItmrJZDLwer1m4XbhwgXouo5AIIB79+4BgOuLNxZuREREVKnBXaXtmpmZ6di6D7O1tYW3334bwB8mmb9x4wbeeusteL1efPLJJyzciIiISDAduDnBDTjJPBERER05nhff1H2J7ChMMs8eNyIiIqokeIFWTyKRwKVLl5DJZFAulyvmSM1mswgGgw5GZw0LNyIiIqrQqZsTnHYUJpln4UZERESVjugYN+APk8wfFAgEHIimea4b43b37l3s7OxYWrZYLOKDDz7obEBE1BLmMpG4juoYN8MXX3yBN998E6dOncK5c+fwySefOB2SZa4r3NLpNLa3tyve0zTNfObKwfcLhUK3QiOiJjCXiQRWflH/JbhQKIS5uTkMDAzgrbfewokTJ7CwsCBMj5vrLpWWy+Wq93Z3dzkJNZFgmMtE4ip/88zpEDoinU7j6dOnePDgQcX4Nk3T8Oabb+KTTz7BX/zFXzgY4eFc1+PWLWtra3jzzTdrdpHu7u7itddecygyImoW85nIZt98Xf8lsEKhgGg0WlG0AXvzqF69ehX5fN6hyKzrycJtZWUFsVjMnPYil8vh8uXLFcuUSiWHoiOiZjCfiexXfvas7ktkpVIJJ06cqPnZ8ePHhWgrerJwW1xcxPz8PFKpFBKJBO7fv4/vfe97+PDDD81lPB6PgxESkVXMZyL7lb/5uu5LZCMjI3XH0967dw8jIyNdjqh5PVm4PX78GGfPnq14L5VKob+/H3fu3HEoKiJqBfOZyH7lb57VfYns6tWrWF5exkcffYSHDx9iZ2fHvKt9bW0NiUTC6RAP5bqbE4C9pxdvbm6a/zcGM3/yyScVA54P3rFm1fDwMLa2tvD6669XvJ9IJBCPx2sOqiai5nU6lwHmM1FHCF6g1eP1enHnzh188MEHyGazAPZupJIkCZ9++ilOnTrlcISH85Rd1qqNjo5id3fX8vIejwcPHz5sahuqqiISiWBiYgLXr1+v+jwWi+H+/ftNr7eWn3z539teRzf95ZB4yfrNn3zf6RCaVhbw0t13v/OdppbvRi4D3cvnb//ppbZ+3gml4k+dDqFpHnedkg51VHP5//7n/1j3sz/6N//OznAcoygKdnZ2IMty1SwKbua6Hre///u/7/g2vF4vfv3rX9f9ln/79u22egCIqDu5DDCfiTpC8LFsVvj9fqdDaInrCrduzhPWaFsizFdG5GbdziHmM5F9RB/LVk+hUMDKygq++OKLqs/OnTuHVCpVNezCbYS/OeHp06dOh0BENmAuE7nHUb054fPPP6/7OJDXX38dmUymyxE1T9jCzbgL5NVXX3U6FCJqA3OZyIWO6AN4d3Z2qu5CN5w9exZbW1tdjqh5rrtU2sjOzg6y2SxWVlag6zrK5TIvgRAJiLlM5G6iP2i3EREestuIEIXb2toastksFEUBAPT39+Py5csIh8OQZdnh6IjIKuYykRhEf9BuPa+//jry+Tzeeuutqs+y2awQD+B1beH28OFDLC8vY2VlxXwOUyAQwNraGr766iu8/PLLDkdIRFYwl4nEU37xwukQOmJmZgZvvPEGfvjDH+Kdd97Byy+/jN3dXXz++efY3t7G6uqq0yEeynWF2xdffIFsNgtN01Aul+H3+xEOhxEIBAAAr7zyisMREpEVzGUicb34+hunQ+gIWZbxi1/8AvF4HFeuXIHH40G5XIYsy7hz544QD+B1XeE2NzeHkydPIpVKIRgMCvNAPCKqxFwmEteLZ0ezcAP2nv24vr4OTdOws7ODEydOCDVUw3V3lZ47dw6PHz/G8vIy7t69y0cEEAmKuUwkrudfP6v7OipkWYbP5xOqaANcWLjdvn0bDx48wOTkJH72s59hdHQUly9fNht+j4DTixD1IuYykbhePPum7ouc5brCDdi70ywcDuP+/fv4+c9/ju9973uYm5vD6OgogL3nPhGR+zGXicTEws29XDfJfCP5fB4rKytQFAUDAwMIh8OYnJys+xRkN+Ak853HSea7o9lJ5hsRMZc5yXx3cJL5zrOSy//zP/yo7mf//N//jZ3hUJOEKtwMmqaZ42Z2d3fx8OFDp0Oq68nT/+N0CE1J/9f/4XQITbv2b/6l0yH0hO9897u2r1OkXP7F5j85HULTLv7oE6dDaNr/LtxwOoQjz0ou//b6O3U/+96Hn9sZDjXJlZdKDyPLMmZmZvDrX/8ad+7ccTocImoRc5nInXip1L1c9ziQZvl8PqdDICIbMJeJ3OM5CzTXEqpwe/r0KXK5HHRdh9/vF+JBeURUjblM5G4vjtBjP44a1xVu29vbmJ2dxc2bNysa8+3tbUQiEXNCao/Hg3A4jI8++si5YImoLuYykbh4SdS9XDfG7fPPP8fu7m7VN/B4PA5d1/Hpp5/iwYMH+Oijj5DNZnH//n2HIiWiRpjLROJ6/vU3dV/kLNcVbtvb2+ZchoZisQhN0zA1NYVAIGA+G+qNN97A3/7t3zoUKRE1wlwmElf5xYu6L3KW6wo3TdNw+vTpivc2NjbMyyn7/dmf/Rm2t7e7GR4RWcRcJhLXi6+f132Rs1w3xk2WZWiaVvFeoVCAJElVD+d8/PhxN0MjoiYwl4nE9fwZCzS3cl2Pm8/nQzabNSekNi6tBIPBqmU1TcPw8HC3QyQiC5jLROJ6/vXzui9ylut63GZmZvCDH/wAY2NjGBkZMafEmZmZqVhud3cXhUIB0WjUoUiJqBHmMpG4nn/NsWxu5boet/7+fnz11Vd47bXXsLm5CZ/Ph5///Od4+eWXK5b7/PO9KTfeeaf+tBxE5BzmMpG4nj97XvdFzhJyrlLD7u4u+vv7nQ6jIc5V2nmcq7Q7OjFXqUGEXOZcpd3BuUo7z0ouF3/wr+t+5vvqv9gZDjXJdZdKm+H2hp6IrGEuE7lL+bmwfTpHntCFGxEREdmPNyG4l+vGuHXL3bt38cUXX2BnZwcAsLa2htdeew2vvfYaPvlEvMsLRL2M+Uxkr+fPXtR9kbN6ssdtcXER6XQasixjYWEBn376Ka5du2Y+pmB5eRnHjx/HpUuXHI6UiA7DfCayHx+06149WbhlMhmsr6/jxIkTmJubw6VLl3Dnzh34fD4AQDQaxeXLl9nQEwmA+UxkP9496l49eam0XC6bT26fmZlBuVw2G3lg74nvT548cSg6ImoG85nIfs+/flH3Rc7qycLN5/PhH/7hH8z/p1Kpis+3t7cxMjLS7bCIqAXMZyL7ceYE9+rJwi2RSGB2dtacimdycrLi82vXrlU93Z2I3In5TGS/8vNy3Rc5qyfHuMmyjPv379f8bHd3Fzdv3sSpU6e6HBURtYL5TGS/Zy94SdSterJwa6S/v5+TXRMdEcxnotZ8/YI9a27Fwo2IiIgqsHBzLxZuREREVIGFm3uxcCMiIqIKfOqHe7FwIyIiogrPy+xxcysWbkRERFSBl0rdi4UbERERVWDh5l4s3IiIiKgCCzf3YuFGREREFZ5xjJtr9eSUV0RERFTf1y/KdV/dpus6stksQqFQ17ftRuxxIyIiogpuuVSqqioURQGwV8ARCzciIiI6wC1zyXu9Xni9XuTzeadDcQ0WbkRERFShUY/b8+fP8aLGJPTHjh1DX19fJ8MiAJ5ymSMQiYiIyJq//uu/xmeffVb1/vvvv48rV650ZJv5fB7pdBrr6+sdWb9I2ONGRERElr333nt49913q94/doz3O3YDCzciIiKyrK+vr6VLoqqqIp1OH7pcKpWCLMuthNYTWLgRERFRx3m9XiwtLTkdhvDYr0lEREQkCN6cQERERK6kaRqWl5dRLBahqiqmpqZw/PhxRKNRp0NzDAs3IiIiIkHwUikRERGRIFi4EREREQmChRsRERGRIFi4EREREQmChRsRERGRIFi4EREREQmChRsRERGRIFi4CSYWi2F0dBTj4+PIZrNOh3MoTdOQyWSQTCadDsUyVVURCoUwNDQk1HE2/jZGR0eRyWScDokOwVzuPOYyHUWcq1QgsVgMu7u7+PLLL6FpGi5evIiBgQEEg0GnQ6spmUxia2sLmqbB5/M5HY5lFy9exPz8PEZGRqAoCuLxuKuPMwBEIhGkUincvn0bmqZhfHwckiQhHA47HRrVwFzuDuYyHUUs3ARSKBSwvr4OSZLg9XoxPT2Ne/fuubYRSqVSAPZOUqJQVRUTExPw+/0AgGAwiHA4jIWFBdceZwBYXV2FJEkAAFmWIcsydF13OCqqh7ncecxlOqp4qVQQiqIA2EtkgyzLKBQKToV0JHm9XvMkZejv73d9w2k09AAwNzeHUqnk6pNTL2MudwdzmY4q9rgJQtO0ioQGKht+6pxCoYBAIOB0GIfKZrPm+KOlpSX+fbgUc9k5zGU6CtjjRtRAMpmELMuYmZlxOpRDhcNhPHr0CEtLS4jH48jn806HROQazGU6Kli4CaLWOIdSqeRQNL1hbm4OwN43XpH4/X5MTExgdnbW6VCoBuZy9zGX6Shh4SaIkZERAHuXWQyqqpoDb8lesVgMx48frxoj40ZuH7NDlZjL3cVcpqOGhZsgJElCIBBAMpmEruvQNA0LCwu8RbwDYrEYTp8+jXA4DF3XzZdbaZqGUCgEVVXN/+dyOUxOTjocGdXCXO4e5jIdRZ5yuVx2OgiyRtd1XLt2DcViEQCQSCRc3djPzc1hZWXFbCglScLk5KSrx5gYD+w8SJIkPHjwwIGIrFFVFel0GltbWxgYGEA4HEY0GnU6LKqDudx5zGU6qli4EREREQmCl0qJiIiIBMHCjYiIiEgQLNyIiIiIBMHCjYiIiEgQLNyIiIiIBMHCjYiIiEgQLNyIiIiIBMHCjYiIiEgQLNyIiIiIBMHCjYiIiEgQLzkdADlLURQkk0nLyycSCQSDwQ5GZM3+uROnpqZcPWciUTcwl4l6Awu3HifLctUExqqqIpvNIhAI4OzZsxWfeb3eboZXUywWw87ODm7cuAFJkmxffz6fh9frhSzLtq+bqFOYy9WYy3QklYkOyOVy5cHBwfLy8rLTodQ0ODhYzuVywq6fqFuYy8xlOno4xo2Eouu60yEQkQ2Yy0StYeFGTctmsxgfHwcAZDIZhEIhKIpi/n9oaKhieU3TMDQ0hHw+X/G+qqqIRCIYGhqqWEc9mUwGo6OjAIB4PI6hoSFkMhnL69M0DclkEuPj4zWXicViZuzG+vfvi9V9a3R8Wtlvok5hLjfeN+YyuRELN2qarusolUqIxWJYWFjAyMgIRkZGmlqHqqoIhULo7+/H0tISfD4fIpEIVFWt+zPhcBirq6sAgKmpKayvryMcDlteXz6fx5MnT5BIJLC6uooTJ04gEolA0zQAwM2bN831JxIJrK+vY319van9Ahofn1b2m6hTmMuNMZfJjXhzArVE13Vsb2/jyy+/bGlQ8ezsLLxeL27fvg0A8Pv90DQN9+7dqztoWpIkc5DxyZMnKwYcW1nfwYHbN2/eRKFQwPLyMmZmZiBJkrmsLMttDWiud3xa2W+iTmIuN8ZcJrdhjxu1LJVKtdTQa5oGVVURDoeh67r5On/+PAqFQtfWJ0kSJEkyv6Xb7eDxsXu/iezCXG6MuUxuwh43almzl1QMRuOaTCarnjvV6snD6vry+Tzu3buH7e1tlEqljg6QPnh87N5vIrswlxtjLpObsHCjlrXaQA0MDAAA1tfXbXm+ktX1RSIRbG1tYXp6Gu+88w5kWcbY2Fjb26/n4PGxe7+J7MJcboy5TG7CS6XUEfu//R4crOv1eiFJEpaXl23ZlpX16boORVFw48YNRKNR82fqaXTJpdG+tRsnkdswl1uLk6hT2ONGtjIa0Fwuh4mJCWxtbSGdTlctd+PGDcTjcezu7prT7mxsbGB7extLS0tNb/ew9RlxLSwsmHFmMpmal1ckSUI2m4Usy1AUBdFoFLIsW963duIkcgvmcntxEnUKe9zIVhMTE/B6vUgmkwiFQsjn85ifn6/6VhwMBrG6ugpN0xCPxxGPx7G9vV11t5hVVtY3Pz9vfp5MJuH3+xEIBKoudUxPT0PTNMzOzuLJkydN71u7cRK5AXO5/TiJOsFTLpfLTgdBRERERIdjjxsRERGRIFi4EREREQmChRsRERGRIFi4EREREQmChRsRERGRIFi4EREREQmChRsRERGRIFi4EREREQmChRsRERGRIFi4EREREQmChRsRERGRIFi4EREREQmChRsRERGRIFi4EREREQmChRsRERGRIFi4EREREQmChRsRERGRIP4fewBe5cE+zmsAAAAASUVORK5CYII=",
            "text/plain": [
              "<Figure size 562.5x262.5 with 3 Axes>"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "plot_sae_feat_cos_sims(sae_corr, toy_model, \"feat 1 partially co-occurs w/feat 0\")"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "qiaU09m7wn_a"
      },
      "source": [
        "Looking at the cosine sim plots above, we see slight absorption happening. Let's test out some real feature activations."
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 149
        },
        "id": "z1rocQVZa1aH",
        "outputId": "6aecceef-ea6c-4676-fdd6-64c4c80a8b68"
      },
      "outputs": [
        {
          "data": {
            "text/html": [
              "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"font-style: italic\">Sample feature values and corresponding SAE activations</span>\n",
              "┏━━━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━━━━━━━━━━━━━━━━┓\n",
              "┃<span style=\"font-weight: bold\">      True features       </span>┃<span style=\"font-weight: bold\">     SAE Latent acts      </span>┃\n",
              "┡━━━━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━━━━━━━━━━━━━━━━━━━┩\n",
              "│  <span style=\"font-weight: bold\">1.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  │  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"font-weight: bold\">1.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  │\n",
              "│  <span style=\"font-weight: bold\">1.00</span>  <span style=\"font-weight: bold\">1.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  │  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"font-weight: bold\">0.66</span>  <span style=\"font-weight: bold\">1.05</span>  │\n",
              "│  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"font-weight: bold\">1.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  │  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">0.00</span>  <span style=\"font-weight: bold\">0.95</span>  │\n",
              "└──────────────────────────┴──────────────────────────┘\n",
              "</pre>\n"
            ],
            "text/plain": [
              "\u001b[3mSample feature values and corresponding SAE activations\u001b[0m\n",
              "┏━━━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━━━━━━━━━━━━━━━━┓\n",
              "┃\u001b[1m \u001b[0m\u001b[1m     True features      \u001b[0m\u001b[1m \u001b[0m┃\u001b[1m \u001b[0m\u001b[1m    SAE Latent acts     \u001b[0m\u001b[1m \u001b[0m┃\n",
              "┡━━━━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━━━━━━━━━━━━━━━━━━━┩\n",
              "│  \u001b[1m1.00\u001b[0m  \u001b[2m0.00\u001b[0m  \u001b[2m0.00\u001b[0m  \u001b[2m0.00\u001b[0m  │  \u001b[2m0.00\u001b[0m  \u001b[2m0.00\u001b[0m  \u001b[1m1.00\u001b[0m  \u001b[2m0.00\u001b[0m  │\n",
              "│  \u001b[1m1.00\u001b[0m  \u001b[1m1.00\u001b[0m  \u001b[2m0.00\u001b[0m  \u001b[2m0.00\u001b[0m  │  \u001b[2m0.00\u001b[0m  \u001b[2m0.00\u001b[0m  \u001b[1m0.66\u001b[0m  \u001b[1m1.05\u001b[0m  │\n",
              "│  \u001b[2m0.00\u001b[0m  \u001b[1m1.00\u001b[0m  \u001b[2m0.00\u001b[0m  \u001b[2m0.00\u001b[0m  │  \u001b[2m0.00\u001b[0m  \u001b[2m0.00\u001b[0m  \u001b[2m0.00\u001b[0m  \u001b[1m0.95\u001b[0m  │\n",
              "└──────────────────────────┴──────────────────────────┘\n"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "test_feats = torch.tensor([\n",
        "    [1, 0, 0, 0],\n",
        "    [1, 1, 0, 0],\n",
        "    [0, 1, 0, 0],\n",
        "])\n",
        "\n",
        "print_sample_feats_and_acts(test_feats, sae_corr, toy_model)"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "fRdLt4Piwx7C"
      },
      "source": [
        "We still see very slight feature absorption occuring in the activation patterns. When both feature 0 and feature 1 are active, the SAE does trigger both latents but it noticely reduces the magnitude of latent 1."
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "Qnod0ZgPVJ-g"
      },
      "source": [
        "# Absorption in Global Batch TopK SAEs\n",
        "\n",
        "So far we've used standard L1 SAEs, but absorption can happen in any type of SAE as increasing sparsity is always beneficial. We need to use a slightly larger toy setup for batch topk SAEs to work, though. First, we'll define a Global Batch TopK SAE class, extending the base SAE class from SAELens. This just selects the topk latents across the whole batch rather than per sample."
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "nY78cyi_VhXs"
      },
      "outputs": [],
      "source": [
        "from torch import nn\n",
        "from sae_lens import TrainingSAE, TrainingSAEConfig\n",
        "\n",
        "class BatchTopK(nn.Module):\n",
        "    def __init__(self, k: int):\n",
        "        super().__init__()\n",
        "        self.k = k\n",
        "\n",
        "    def forward(self, x: torch.Tensor) -> torch.Tensor:\n",
        "        acts = x.relu()\n",
        "        acts_topk = torch.topk(acts.flatten(), self.k * acts.shape[0], dim=-1)\n",
        "        return (\n",
        "            torch.zeros_like(acts.flatten())\n",
        "            .scatter(-1, acts_topk.indices, acts_topk.values)\n",
        "            .reshape(acts.shape)\n",
        "        )\n",
        "\n",
        "class BatchTopkSAE(TrainingSAE):\n",
        "    def __init__(self, cfg: TrainingSAEConfig):\n",
        "        super().__init__(cfg)\n",
        "        if cfg.architecture != \"topk\":\n",
        "            raise ValueError(\"BatchTopkSAE requires topk architecture\")\n",
        "        self.activation_fn = BatchTopK(cfg.activation_fn_kwargs[\"k\"])"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "zgIJg8UGVrLU"
      },
      "source": [
        "We'll use a larger toy model than previously with 12 true features instead of 4, since it's difficult to use a topk SAE with so few features. These 12 features fire with probability 0.15, except for feature 0, the parent feature, and feature 1, the child feature. Feature 0 fires with probability 0.4, and feature 1 fires with probability 0.6 if feature 0 is firing."
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "y0bTGjAEWIMh"
      },
      "outputs": [],
      "source": [
        "large_toy_model = ToyModel(num_feats=12).to(DEFAULT_DEVICE)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "QEwJKgh5V2LG",
        "outputId": "aa381d3d-153c-4ed4-cca5-559c00234c20"
      },
      "outputs": [
        {
          "name": "stderr",
          "output_type": "stream",
          "text": [
            "50000| auxiliary_reconstruction_loss: 0.00000 | mse_loss: 0.00000: 100%|██████████| 25000000/25000000 [02:30<00:00, 166216.71it/s]\n"
          ]
        }
      ],
      "source": [
        "from functools import partial\n",
        "\n",
        "# We set up feature 1 to only be allowed to fire if feature 0 is also firing\n",
        "def modify_feats(feats: torch.Tensor):\n",
        "    feat_0_fires = feats[:, 0] == 1\n",
        "    feats[~feat_0_fires, 1] = 0\n",
        "    return feats\n",
        "\n",
        "feat_probs = torch.tensor([0.15] * 12)\n",
        "feat_probs[0] = 0.4\n",
        "feat_probs[1] = 0.6\n",
        "\n",
        "\n",
        "def modify_feats(feats: torch.Tensor):\n",
        "    feat_0_fires = feats[:, 0] == 1\n",
        "    feats[~feat_0_fires, 1] = 0\n",
        "    return feats\n",
        "\n",
        "generate_batch = partial(\n",
        "    get_training_batch,\n",
        "    firing_probabilities=feat_probs,\n",
        "    modify_firing_features=modify_feats,\n",
        ")\n",
        "\n",
        "# NOTE: occasionaly this gets stuck in poor local minima. If this happens, try rerunning and it should converge properly.\n",
        "topk_sae_abs = train_toy_sae(\n",
        "    large_toy_model,\n",
        "    generate_batch,\n",
        "    sae_class=BatchTopkSAE,\n",
        "    d_sae=12,\n",
        "    architecture=\"topk\",\n",
        "    activation_fn_kwargs={\"k\": 2},\n",
        "    training_tokens=25_000_000,\n",
        ")"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 855
        },
        "id": "J4R9xSAfZedg",
        "outputId": "34c66035-60d6-4a5a-eb10-4508597cde54"
      },
      "outputs": [
        {
          "name": "stderr",
          "output_type": "stream",
          "text": [
            "16800| l1_loss: 0.00188 | mse_loss: 0.00000:  69%|██████▉   | 68812800/100000000 [1:31:56<41:40, 12474.17it/s]\n",
            "Training SAE:   0%|          | 0/100000000 [1:21:33<?, ?it/s]\n",
            "1900| auxiliary_reconstruction_loss: 0.00000 | mse_loss: 0.35611:   5%|▌         | 7782400/150000000 [1:13:58<22:31:45, 1753.49it/s]\n"
          ]
        },
        {
          "data": {
            "image/png": "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",
            "text/plain": [
              "<Figure size 750x375 with 3 Axes>"
            ]
          },
          "execution_count": 63,
          "metadata": {},
          "output_type": "execute_result"
        },
        {
          "data": {
            "image/png": "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",
            "text/plain": [
              "<Figure size 750x375 with 3 Axes>"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "plot_sae_feat_cos_sims(topk_sae_abs, large_toy_model, \"feat 1 co-occurs w/feat 0, batch topk SAE\", figsize=(5.0, 2.5))"
      ]
    }
  ],
  "metadata": {
    "accelerator": "GPU",
    "colab": {
      "collapsed_sections": [
        "oZfr2ude2HEi"
      ],
      "gpuType": "T4",
      "machine_shape": "hm",
      "provenance": []
    },
    "kernelspec": {
      "display_name": "Python 3",
      "name": "python3"
    },
    "language_info": {
      "name": "python"
    }
  },
  "nbformat": 4,
  "nbformat_minor": 0
}
