Fix FactoredMatrix indexing returning empty result for -1 index#1340
Merged
jlarson4 merged 7 commits intoMay 28, 2026
Merged
Conversation
* Fix type of HookedTransformerConfig.device This is typed as `Optional[str]` but sometimes returns `torch.device`. Updated the code to just return the `str` instead of wrapping with a device. I'm not confident that every function which takes a device will always be passed a string, so I didn't change functions like warn_if_mps. Found while working on TransformerLensOrg#1219 * more cleanup * 3.0 CI Bugs (TransformerLensOrg#1261) * Fixing `utils` imports * skip gated notebooks on PR from forks * Updating notebooks * Ensure LLaMA only runs when HF_TOKEN is available --------- Co-authored-by: jlarson4 <jonahalarson@comcast.net>
TransformerLens 3.1.0
* Fix TransformerBridge backward hook cleanup * Preserve backward hooks in run_with_cache
FactoredMatrix.__getitem__ converts an integer index `v` into the matrix (ldim/rdim) dimensions to `slice(v, v + 1)`. For `v == -1` this becomes `slice(-1, 0)`, which is an empty slice, so indexing the last row/column with a negative index silently returns a (0, ...) tensor instead of the requested element. Other negative indices (-2, -3, ...) are unaffected because `v + 1` stays negative. Use `None` as the slice stop when `v == -1` so the final element is kept. Adds regression tests covering negative indices on each matrix dimension.
Collaborator
|
Excellent work on this @Kymi808! Thanks for your contribution, merging now |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
Description
FactoredMatrix.__getitem__routes an integer index into the matrix (ldim/rdim) dimensions through_convert_to_slice, which turns an intvintoslice(v, v + 1). Forv == -1this becomesslice(-1, 0)— an empty slice — so indexing the last row/column with a negative index silently returns a(0, ...)tensor instead of the requested element.Only
-1is affected; other negative indices (-2,-3, …) work becausev + 1stays negative and produces a valid slice.Fix
In
_convert_to_slice, useNoneas the slice stop whenv == -1, soslice(-1, None)keeps the final element. Positive indices and other negatives are unchanged.Type of change
Checklist:
tests/unit/factored_matrix/test_get_item.py; they fail onmainand pass with this change)pytest tests/unit/factored_matrix/→ 147 passed, 1 skipped)