Neural network backend for training and inference for animal pose estimation.
Project description
sleap-nn
Neural network backend for training and inference for animal pose estimation.
This is the deep learning engine that powers SLEAP (Social LEAP Estimates Animal Poses), providing neural network architectures for multi-instance animal pose estimation and tracking. Built on PyTorch, SLEAP-NN offers an end-to-end training workflow, supporting multiple model types (Single Instance, Top-Down, Bottom-Up, Multi-Class), and seamless integration with SLEAP's GUI and command-line tools.
Need a quick start? Refer to our Quick Start guide in the docs.
Documentation
📚 Documentation - Comprehensive guides and API reference
For development setup
- Clone the sleap-nn repo
git clone https://github.com/talmolab/sleap-nn.git
cd sleap-nn
# macOS/Linux
curl -LsSf https://astral.sh/uv/install.sh | sh
# Windows
powershell -c "irm https://astral.sh/uv/install.ps1 | iex"
- Install sleap-nn dependencies based on your platform\
Python 3.14 is not yet supported
sleap-nncurrently supports Python 3.11, 3.12, and 3.13.
Python 3.14 is not yet tested or supported.
By default,uvwill use your system-installed Python.
If you have Python 3.14 installed, you must specify the Python version (≤3.13) in the install command.For example:
uv sync --python 3.13 ...Replace
...with the rest of your install command as needed.
-
Sync all dependencies based on your correct wheel using
uv sync.uv synccreates a.venv(virtual environment) inside your current working directory. This environment is only active within that directory and can't be directly accessed from outside. To use all installed packages, you must run commands withuv run(e.g.,uv run sleap-nn train ...oruv run pytest ...).- Windows/Linux with NVIDIA GPU (CUDA 13.0):
uv sync --extra torch-cuda130
- Windows/Linux with NVIDIA GPU (CUDA 12.8):
uv sync --extra torch-cuda128
- Windows/Linux with NVIDIA GPU (CUDA 11.8):
uv sync --extra torch-cuda118
- macOS with Apple Silicon (M1, M2, M3, M4) or CPU-only (no GPU or unsupported GPU): Note: Even if torch-cpu is used on macOS, the MPS backend will be available.
uv sync --extra torch-cpu
-
Run tests
uv run pytest tests
-
(Optional) Lint and format code
uv run black --check sleap_nn tests uv run ruff check sleap_nn/
Upgrading All Dependencies To ensure you have the latest versions of all dependencies, use the
--upgradeflag withuv sync:uv sync --upgradeThis will upgrade all installed packages in your environment to the latest available versions compatible with your
pyproject.toml.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file sleap_nn-0.1.0a2.tar.gz.
File metadata
- Download URL: sleap_nn-0.1.0a2.tar.gz
- Upload date:
- Size: 19.1 MB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.9.26 {"installer":{"name":"uv","version":"0.9.26","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
dda7c641003852f7a2006374c55bb1585957969242bd534a35f6b563d64d0f2b
|
|
| MD5 |
b8684b74ac61c73c9a3103a360adef99
|
|
| BLAKE2b-256 |
9e9b956b54ade0c1543c4714bff04496ad28335254d3817f851b10ca1d83a803
|
File details
Details for the file sleap_nn-0.1.0a2-py3-none-any.whl.
File metadata
- Download URL: sleap_nn-0.1.0a2-py3-none-any.whl
- Upload date:
- Size: 251.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.9.26 {"installer":{"name":"uv","version":"0.9.26","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b65b18531006e425b57150421b9bb46599d089a0d064e25588c94233a48a39e3
|
|
| MD5 |
8cce8a08f842a69ccc53408f62025dbf
|
|
| BLAKE2b-256 |
9927b8bfe9791fa02d7e2d4ef0efe289a49f210131b02ea185957636fa159875
|