Analyzing the Generalization and Reliability of Steering Vectors
Daniel Tan, David Chanin, Aengus Lynch, Dimitrios Kanoulas, Brooks Paige, Adria Garriga-Alonso, Robert Kirk
TL;DR
<3-5 sentence high-level summary> This paper rigorously evaluates steering vectors (SVs) as inference-time interventions that modify intermediate activations to steer language model behavior. Using a broad suite of Model-Written Evaluations (MWE) and controlled prompt distribution shifts, it quantifies in-distribution steerability and out-of-distribution generalisation. The key findings reveal substantial per-sample variability, anti-steerable cases, and a prominent steerability bias tied to tokens/positions, with generalisation largely dependent on dataset properties and model propensity. The results highlight that while SVs can work in some settings, they are not a universal, scalable solution and require further work to understand and mitigate biases and to improve cross-prompt generalisation.
Abstract
Steering vectors (SVs) have been proposed as an effective approach to adjust language model behaviour at inference time by intervening on intermediate model activations. They have shown promise in terms of improving both capabilities and model alignment. However, the reliability and generalisation properties of this approach are unknown. In this work, we rigorously investigate these properties, and show that steering vectors have substantial limitations both in- and out-of-distribution. In-distribution, steerability is highly variable across different inputs. Depending on the concept, spurious biases can substantially contribute to how effective steering is for each input, presenting a challenge for the widespread use of steering vectors. Out-of-distribution, while steering vectors often generalise well, for several concepts they are brittle to reasonable changes in the prompt, resulting in them failing to generalise well. Overall, our findings show that while steering can work well in the right circumstances, there remain technical difficulties of applying steering vectors to guide models' behaviour at scale. Our code is available at https://github.com/dtch1997/steering-bench
