Skip to main content

Deep learning step selection functions for predicting animal movement.

Project description

deepSSF

Predicting animal movement with a deep learning step-selection framework.

This package provides the installable implementation of the deepSSF approach in Python. Accompanying tutorials and example code live at the deepSSF project site.

There is a package walkthrough script that outlines an implementation of the functions with some example GPS tracking data (a single water buffalo) and two spatial covariates (NDVI and slope). You can access the script as a Jupyter notebook or as a knitted html in the examples directory. The example script will not download with the package installation, but the GPS and spatial datasets will.

The Python package can be viewed on PyPi.

The paper can be found at:

Forrest, S. W., Pagendam, D., Hassan, C., Potts, J. R., Drovandi, C., Bode, M., & Hoskins, A. J. (2026). Predicting animal movement with deepSSF : A deep learning step selection framework. Methods in Ecology and Evolution, 17(2), 371–391. https://doi.org/10.1111/2041-210x.70136.

Installation (pip only)

If you manage your own Python environment, install deepSSF with:

pip install deepssf

Development install (editable, with linting and testing tools):

git clone https://github.com/swforrest/deepssf
cd deepssf
pip install -e ".[dev]"

Quick start

import deepssf
print(deepssf.__version__)

Setting up (for users new to Python)

If you are coming from R, think of a conda environment the way you think of an renv project library — it is a self-contained Python installation that keeps this project's packages separate from everything else on your computer. The steps below create one for deepssf and should take about five minutes.

1. Install Miniconda (once, system-wide)

Download and run the installer from the official Miniconda page.

  • Windows: use the Anaconda Prompt for all subsequent commands, and choose an install path that contains no spaces (e.g. C:\miniconda3).
  • macOS / Linux: a normal terminal works fine.

Miniforge alternative: if you prefer to avoid Anaconda's default channel entirely, Miniforge is a drop-in replacement that ships with conda-forge as the only channel.

2. Create the environment

git clone https://github.com/swforrest/deepssf
cd deepssf
conda env create -f environment.yml

This installs Python 3.11, the geospatial libraries (rasterio / GDAL / PROJ), Jupyter Lab, and the deepSSF package itself with all of its dependencies. PyTorch is installed via pip with no extra flags — pip automatically picks the right build for your hardware: MPS on Apple Silicon, CUDA on NVIDIA GPUs, CPU everywhere else. No configuration is needed; the package selects the correct backend at runtime.

3. Activate the environment

conda activate deepssf

You will need to run this once per terminal session before using deepSSF.

4. (Optional) Register the Jupyter kernel

If you use VS Code or another editor that manages its own Jupyter kernel list, register the environment so it appears as a kernel option:

python -m ipykernel install --user --name deepssf --display-name "Python (deepssf)"

5. Launch Jupyter Lab

jupyter lab

Then open examples/deepssf_train_validate_example.ipynb to get started.


Documentation

Tutorials and walkthroughs: https://swforrest.github.io/deepSSF/

Citation

If you use deepssf in your research, please cite the paper. See CITATION.cff or use the citation and link to paper below.

Forrest, S. W., Pagendam, D., Hassan, C., Potts, J. R., Drovandi, C., Bode, M., & Hoskins, A. J. (2026). Predicting animal movement with deepSSF : A deep learning step selection framework. Methods in Ecology and Evolution, 17(2), 371–391. https://doi.org/10.1111/2041-210x.70136

License

MIT — see LICENSE.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

deepssf-0.2.1.tar.gz (21.6 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

deepssf-0.2.1-py3-none-any.whl (7.9 MB view details)

Uploaded Python 3

File details

Details for the file deepssf-0.2.1.tar.gz.

File metadata

  • Download URL: deepssf-0.2.1.tar.gz
  • Upload date:
  • Size: 21.6 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for deepssf-0.2.1.tar.gz
Algorithm Hash digest
SHA256 09ea98a6e0a62917639d46bb393f5f169fa2a1baf0a5b751f7d20fd3ab7e5f58
MD5 1f701ee42798b173d3a14636abc85653
BLAKE2b-256 bebe3b9d42ae22675288d88e490dd3f3cc49ac559a9382613fc9372e3eac1fe5

See more details on using hashes here.

Provenance

The following attestation bundles were made for deepssf-0.2.1.tar.gz:

Publisher: publish.yml on swforrest/deepSSF_package

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file deepssf-0.2.1-py3-none-any.whl.

File metadata

  • Download URL: deepssf-0.2.1-py3-none-any.whl
  • Upload date:
  • Size: 7.9 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for deepssf-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 09553d3c6724ed09ab0000d164d00abe5bee65926d3c07e66bdbfde1521c34d5
MD5 6ea61b75b268d552677ba569183f38c1
BLAKE2b-256 675c2dd47eb33eab80f29051c47036139f4c2b5aec0ab73ec66e6ec6138cce73

See more details on using hashes here.

Provenance

The following attestation bundles were made for deepssf-0.2.1-py3-none-any.whl:

Publisher: publish.yml on swforrest/deepSSF_package

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page