Contributions are welcome, and they are greatly appreciated! Every little bit helps, and credit will always be given.
You can contribute in many ways:
Report bugs on GitHub.
If you are reporting a bug, please include:
- Your TorchIO version.
- Any details about your local setup that might be helpful in troubleshooting.
- Detailed steps to reproduce the bug.
Look through the GitHub issues for bugs. Anything tagged with "bug" and "help wanted" is open to whoever wants to implement it.
Look through the GitHub issues for features. Anything tagged with "enhancement" and "help wanted" is open to whoever wants to implement it.
TorchIO could always use more documentation, whether as part of the official TorchIO docs, in docstrings, or even on the web in blog posts, articles, and such.
The best way to send feedback is to file an issue at https://github.com/fepegar/torchio/issues.
If you are proposing a feature:
- Explain in detail how it would work.
- Keep the scope as narrow as possible, to make it easier to implement.
- Remember that this is a volunteer-driven project, and that contributions are welcome :)
Ready to contribute? Here's how to set up torchio
for local development.
It's good practice to first discuss the proposed changes as the feature might already be implemented.
git clone git@github.com:your_github_username_here/torchio.git
cd torchio
uv is recommended for development.
You can use just to set up the development environment.
This will 1) install uv
if not found and 2) install torchio
and all its
dependencies:
just setup
For example, if the issue number is 55:
git checkout -b 55-name-of-your-bugfix-or-feature
Now you can make your changes locally.
When you're done making changes, check that your changes pass the tests
using pytest
:
uv run pytest -x
Here's some great advice to write good commit messages, and here's some more):
git add .
git commit -m "Fix nasty bug"
git push origin 55-name-of-your-bugfix-or-feature
If you have modified the documentation or some docstrings, build the docs and verify that everything looks good:
cd docs
make html
You can also use livehtml
instead, to automatically build the docs every
time you modify them and reload them in the browser:
make livehtml
If you prefer to activate your environment manually or not use uv
,
add PREFIX=""
to the command:
make html PREFIX=""
To run a subset of tests:
pytest tests/data/test_image.py