MVA course project: experimental validation of key claims in StelLA: Subspace Learning in Low-Rank Adaptation using Stiefel Manifold, with controlled small-scale experiments.
To install this package, run:
pip install stellatscaleExample usage:
import stellatscale
...src/stellatscale: installable package codetests: test suitescripts: runnable research and benchmarking scriptsnotebooks: exploratory notebooksdeliverables: paper, poster, and report sourcesdocs: MkDocs content
Run the comparison and benchmark scripts from the repository root:
uv run poe bench
uv run python -m scripts.bench_efficiency
uv run python -m scripts.bench_expressivityThe notebook used for exploration lives at notebooks/notebook.ipynb.
The minimal transformer backbone used by the research models is adapted from
nanoGPT by Andrej Karpathy under the MIT License. The project keeps the full
license text and attribution in THIRD_PARTY_NOTICES.md.
Prerequisites
-
Generate an SSH key and add the SSH key to your GitHub account.
-
Configure SSH to automatically load your SSH keys:
cat << EOF >> ~/.ssh/config Host * AddKeysToAgent yes IgnoreUnknown UseKeychain UseKeychain yes ForwardAgent yes EOF
-
Install VS Code and VS Code's Dev Containers extension. Alternatively, install PyCharm.
-
Optional: install a Nerd Font such as FiraCode Nerd Font and configure VS Code or PyCharm to use it.
Development environments
The following development environments are supported:
-
⭐️ GitHub Codespaces: click on Open in GitHub Codespaces to start developing in your browser.
-
⭐️ VS Code Dev Container (with container volume): click on Open in Dev Containers to clone this repository in a container volume and create a Dev Container with VS Code.
-
⭐️ uv: clone this repository and run the following from root of the repository:
git clone git@github.com:the-tuning-machine/SteLA_Project.git cd SteLA_Project # Create and install a virtual environment uv sync --python 3.12 --all-extras # Activate the virtual environment source .venv/bin/activate # Install the pre-commit hooks pre-commit install --install-hooks
-
VS Code Dev Container: clone this repository, open it with VS Code, and run Ctrl/⌘ + ⇧ + P → Dev Containers: Reopen in Container.
-
PyCharm Dev Container: clone this repository, open it with PyCharm, create a Dev Container with Mount Sources, and configure an existing Python interpreter at
/opt/venv/bin/python.
Developing
- This project follows the Conventional Commits standard to automate Semantic Versioning and Keep A Changelog with Commitizen.
- Run
poefrom within the development environment to print a list of Poe the Poet tasks available to run on this project. - Run
uv add {package}from within the development environment to install a run time dependency and add it topyproject.tomlanduv.lock. Add--devto install a development dependency. - Run
uv sync --upgradefrom within the development environment to upgrade all dependencies to the latest versions allowed bypyproject.toml. Add--only-devto upgrade the development dependencies only. - Run
cz bumpto bump the package's version, update theCHANGELOG.md, and create a git tag. Then push the changes and the git tag withgit push origin main --tags.