Interpretable Analysis of Features Found in Open-source Sparse Autoencoder (partial replication)

By Fernando Avalos @ 2024-08-28T22:08 (+6)

This project was carried out as part of the “Carreras con Impacto” program during the 14-week mentorship phase. You can find more information about the program in this entry.

Objective

The objective of the project was to develop expertise in Mechanistic Interpretability by:

  1. Studying Sparse Autoencoders and their role in aiding interpretability of AI models
  2. Analysing interpretable features in an open-source Sparse Autoencoder
  3. Signal robust understanding of the underlying concepts of the previous objectives

I'll focus more on the big-picture, intuitive overview of the concepts rather than in their formal mathematical details. The content of the explanations shouldn’t be taken as teaching material of some sort but rather a reflection of my understanding.

The structure of the post mimics the objectives, so if you are already familiar with Sparse Autoencoders and their role in Mechanistic Interpretability, start reading from the "Anthropic paper overview" section.

The big picture

At its core, an artificial neural network is a mathematical function that transforms input data into output data. This transformation occurs through layers of interconnected nodes, or "neurons," each performing simple mathematical operations.

  1. Basic Building Blocks:
    • Neurons receive inputs, apply weights, sum the results, and pass them through an activation function.
    • Layers of neurons process information sequentially, with each layer's output serving as input for the next.
  2. Learning Process:
    • The network "learns" by adjusting its weights to minimize the difference between its predictions and actual outcomes.
    • This process, known as training, involves exposing the network to vast amounts of data.
  3. Emergence of Complexity:
    • As networks grow larger and are exposed to more diverse data, they develop the ability to recognize increasingly complex patterns.
    • However, this comes at a cost: the internal representations become harder to interpret.
  4. The Superposition Challenge:
    • In large models, individual neurons often respond to multiple, sometimes unrelated concepts.
    • This phenomenon, called "superposition," makes it difficult to isolate and understand specific functionalities within the model.
  5. Quest for Interpretability:
    • Researchers aim to "open the black box" by identifying interpretable components within these complex networks.
    • These components, often called "features" or "circuits," represent specific, understandable functionalities.
  6. Sparse Autoencoders:
    • Recent research introduces a method to "decode" the complex internal representations of large language models.
    • This approach, using tools called Sparse Autoencoders, works like a translator for the model's internal language.
    • It attempts to break down the mixed-up (superposed) information in the model into clearer, more understandable pieces.
    • The goal is to find simple, interpretable features that can explain the model's behavior, similar to finding individual instruments in a complex musical piece.
  7. Mathematical Framework:
    • Features can be conceptualized as directions in a high-dimensional space, where each dimension corresponds to a neuron.
    • Linear algebra provides the tools to analyse and manipulate these high-dimensional representations.

By pursuing interpretability, researchers aim to not only understand these systems but also to improve their reliability, address biases, and potentially design more efficient and powerful AI systems in the future.

Anthropic paper overview

The team behind the paper sought to derive monosemanticty the smallest non-interpretable by default model that there exists, a 1-layer Transformer.

Architecture of the 1-layer Transformer

As the image tells, they trained sparse, overcomplete autoencoders over the MLP activations of the model. Sparsity and overcompleteness are enforced because both intuitively lead to an interpretable disentanglement of the input, since the MLP activations are presumed to be in superposition.

Mathematical formulation

An Sparse Autoencoder is mathematically defined by the following elements:

In the context of the paper, n  is set to number of output neurons in the MLP layer, whereas m is variable, as the authors performed various runs with the parameter ranging from 512 to 131072.

Training process

  1. Forward pass: Compute x and x'
  2. Compute loss: Calculate the sparsity penalty and the reconstruction error
  3. Backpropagation: Update the encoding & decoding matrices and biases to minimise the loss
  4. Iterate until convergence or for a fixed number of epochs

Results

After training the Sparse Autoencoders, monosemantic features were found. One of the principal lines of evidences for assessing monosemanticity are the so-called "detailed investigations", which are comprised of the following criteria:

The following criteria was used to rigorously evaluate whether a feature existed or not:

Inspecting an open-source Sparse Autoencoder

Are the findings of the Anthropic team replicable? In order to know it, I analysed an Sparse Autoencoder trained over the MLP activations of an open-source 1-layer transformer. Originally, I planned to replicate the experiments of the Anthropic paper (i.e. understanding the logic behind each experiment and generating the graphs myself) even though I was already aware that the sae-vis library existed but desisted in doing so because I was not advancing at a good pace. Therefore, sae-vis was used to aid the analysis.

How to find ostensibly interpretable features?

The sae-vis library offers feature-centric and prompt-centric visualisations. The former generates information from a feature given its index whereas the latter generates information about the features that activate the most for a specific prompt.

My process for seeking interesting features was the following:

  1. Construct 3 prompts rich in grammar structures, allusions to countries and common code directives. The rationale for doing so lies in the fact that the 1-layer transformer model was trained on a mixture of python code and English text. As such, it is reasonable to expect the existence of features related to those concepts.
  2. Generate prompt-centric visualisations given the 3 prompts from the previous point and manually search for features that seem interesting according to the logit distribution and max activating samples.
  3. Generate feature-centric visualisations per each feature found in the previous point for further inspection.

Found features

In this Google Colab notebook you can detail the search process was carried out, with each found feature having its own feature-centric visualisation.

Full-stop

Specificity

The feature exhibits the following activation histogram:

Activation histogram for the full-stop detector
Max activating samples for the full-stop detector

The feature strongly activates for full-stops, as seen in the activation histogram's right tail. It doesn't activate for any other tokens, demonstrating high specificity.

Sensitivity

The feature activates for all full-stops in top samples, indicating high sensitivity.

Downstream effects

Logit weights distribution for the full-stop detector

The words with higher logits are primarily discourse markers - grammatical elements commonly found after full stops in natural language.

Feature is not a neuron

Relevant statistics for the full-stop detector

The low Pearson correlation values indicate this feature is not a neuron.

"for" control structure

Specificity

Activation histogram for the "for" detector
Max activating samples for the "for" detector

The feature strongly activates for the keyword for in top samples, demonstrating high specificity.

Sensitivity

The feature activates for all instances of the keyword for in top samples, indicating high sensitivity.

Downstream effects

Logit weight distribution for the "for" detector

The words with higher positive logits are primarily Python-specific elements commonly used after for in loop constructs, while negative logits show punctuation and general language elements.

Feature is not a neuron

Relevant statistics for the "for" detector

The low Pearson correlation values indicate this feature is not a neuron.

else control structure

Specificity

Activation histogram for the "else" detector
Max activating samples for the "else" detector

The feature strongly activates for the keyword else in top samples, demonstrating high specificity.

Sensitivity

The feature activates for all instances of the keyword else in top samples, indicating high sensitivity.

Downstream effects

Logit weight distribution for the "else" detector

The feature shows balanced positive and negative logits, not clearly indicating Python else usage. Positive logits don't match typical else follow-ups, while negative logits include various unrelated tokens. This suggests the feature may capture broader syntactic patterns beyond simple else detection.

Feature is not a neuron

Relevant statistics for the "else" detector

The low Pearson correlation values indicate this feature is not a neuron.

"import" keyword

Specificity

Activation histogram for the "import" keyword
Max activating samples for the "import" keyword

The feature strongly activates for the keyword import in top samples, demonstrating high specificity.

Sensitivity

The feature activates for all instances of the keyword import in top samples, indicating high sensitivity.

Downstream effects

Logit weight distribution for the "import" keyword

The positive logits strongly indicate Python-related libraries and modules (numpy, json, datetime, pandas), suggesting this feature detects Python import contexts. Negative logits show unrelated or partial words, further emphasising the feature's specificity to Python library imports.

Feature is not a neuron

Relevant statistics for the "import" detector

The low Pearson correlation values indicate this feature is not a neuron.

Retrospective

Beware of re-inventing the wheel

The original intent behind the project was to not only replicate Anthropic's findings but also replicate the visualisation artefacts themselves (activation histogram, logit distribution graph, etc.) even though I was aware of the existence of the sae-vis library. I thought this was a good idea since successfully executing it signalled that I had a robust understanding of the material. Moreover, I underestimated the amount of time it would take me to understand the source paper, set up the coding environment and reverse engineer the plots.

Eventually, I desisted on doing a full-scope replication and focused on getting simple but not less rigorous results. In future endeavours I will try to assess the value of doing a replication and leverage existing tools.

Don't miss the forest for the trees

While trying to replicate Anthropic's paper plots, I fixated on getting every detail right and understanding how the plots were made from both the logic and visual aspects. This led me to spend considerable time figuring out details that, while interesting, were not central to the object-level phenomena. 

Asking for help is good, actually

Throughout a large part of the program, I hesitated to ask for help when faced with challenges. I used to think (and still do) that figuring out things on your own is an important skill to have but it is necessary to be mindful of when that mindset can be giving diminishing returns or halting progress altogether. If you have been wasting considerably more time than you think on doing an specific task, don't hesitate to ask for help. Even if the task could actually have been completed on your own on the initial timeframe, you could still nurture your intuition by hearing other's trains of thought and insights.

De-risk aggressively

I realised the importance of validating core assumptions early in the project. In retrospect this element is overly obvious but sometimes people don't act on it out of confident. I had to core assumptions that weren't as black and white as I thought, meaning I should have spent more time exploring the nuances of them:

  1. A replication in and of itself has value
  2. There is no way a replication project can go wrong, since the methods, data, etc. are all well known

The extent to which each of those statements is true is contingent on career stage, relevance of the papers to replicate, what skills will be built and, more importantly, the level of detail (or the explicitness) of the source material's methodology.

Next steps

Conduct further experiments

Since the scope of the project was shortened due to some strategic errors in my part, a natural path to make the work more relevant is to enrich it with experiments that the Anthropic team did not conduct. Here is an example of an experiment worth replicating to characterise the nature of the found features.

Work through (partially) the ARENA curriculum

Undertaking this project whilst having a broad understanding of the Transformer architecture and Superposition theory was perhaps too ambitious. As such, I plan to work through some parts of the ARENA curriculum, hoping to strengthen my understanding of the foundations for Alignment Research & Engineering.

Explore other facets of AI Safety

After attending an ML4Good bootcamp, I became progressively more interested in holistic and big-picture discussions about AI Safety. That, coupled with the fact I'm still not sure my abilities would be better invested in the technical side (given my experience with this project), led me to enroll in the Governance track of BlueDot's AI Safety Fundamentals course and co-found AI Safety Initiative Colombia. If I get the desired results, I might consider re-orienting my career towards Technical Governance and Field-building.

References


SummaryBot @ 2024-08-29T15:13 (+1)

Executive summary: The author analyzes interpretable features in an open-source Sparse Autoencoder trained on a 1-layer Transformer, partially replicating findings from an Anthropic paper on deriving monosemantic features from language models.

Key points:

  1. Sparse Autoencoders are used to "decode" complex internal representations of large language models into more interpretable features.
  2. The author inspected an open-source Sparse Autoencoder, finding interpretable features like full-stop detection, "for" and "else" control structures, and the "import" keyword.
  3. Features were evaluated on criteria including specificity, sensitivity, downstream effects, and not being a single neuron.
  4. Key lessons learned include leveraging existing tools, maintaining big-picture focus, asking for help when needed, and early validation of core assumptions.
  5. Future steps include conducting additional experiments, working through parts of the ARENA curriculum, and exploring other aspects of AI safety.

 

 

This comment was auto-generated by the EA Forum Team. Feel free to point out issues with this summary by replying to the comment, and contact us if you have feedback.