Posts
Comments
Fourth, and most importantly, if superposition happens more in narrower layers, and if superposition is a cause of adversarial vulnerabilities, this would predict that deep, narrow networks would be less adversarially robust than shallow, wide networks that achieve the same performance and have the same number of parameters. However, Huang et al., (2022) found the exact opposite to be the case.
I'm not sure why the superposition hypothesis would predict that narrower, deeper networks would have more superposition than wider, shallower networks. I don't think I've seen this claim anywhere—if they learn all the same features and have the same number of neurons, I'd expect them to have similar amounts of superposition. Also, can you explain how the feature hypothesis "explains the results from Huang et al."?
More generally, I think superposition existing in toy models provides a plausible rational for adversarial examples both being very common (even as we scale up models) and also being bugs. Given this and the Elhage et al. (2022) work (which is bayesian evidence towards the bug hypothesis, despite the plausibility of confounders), I'm very surprised you come out with "Verdict: Moderate evidence in favor of the feature hypothesis."
Makes sense! Depends on if you're thinking about the values as "estimating zero ablation" or "estimating importance."
Very cool work!
- In the attention attribution section, you use
clean_pattern * clean_pattern_grad
as an approximation of zero ablation; should this be-clean_pattern * clean_pattern_grad
? Zero ablation's approximation is(0 - clean_pattern)*clean_pattern_grad = -clean_pattern * clean_pattern_grad
.- Currently, negative name movers end up with negative attributions, but we'd like them to be positive (since zero ablating helps performance and moves our metric towards one), right?
- Of course, this doesn't matter when you are just looking at magnitudes.
- Cool to note we can approximate mean ablation with (means - clean_act) * clean_grad_act!
- (Minor note: I think the notebook is missing a `model.set_use_split_qkv_input(True)`. I also had to remove `from transformer_lens.torchtyping_helper import T`.)