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 already have a Python environment that you want to install the package into, 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)

1. Install Miniconda (once, system-wide)

Download and run the installer from the official Miniconda page.

If you click 'Download' towards the top right, the links to download Miniconda are towards the bottom of the page - the links at the top are for the Anaconda Distribution, which has thousands of pacakges and is not necessary to get things up and running initially.

1b. (Optional) Install an IDE (such as VSCode)

Once you have Python and Miniconda installed, you will likely want an interface (‘Integrated Development Environment’, an IDE) to code in (such as RStudio for R users). I use Visual Studio Code, or ‘VS Code’ as I find the functionality similar to RStudio (and as I have become familiar with VS Code I prefer it to RStudio in some ways).

You can download VSCode from here: https://code.visualstudio.com/.

For the commands below, you can use the Terminal directly in VScode (Terminal > New Terminal), or the Terminal/Command Line in Windows or macOS.

2. Create the environment

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.

Using the Terminal (which can be in VScode), you can clone the package repository with:

git clone https://github.com/swforrest/deepssf_package
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

Also in the Terminal:

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)"

Then you can open examples/deepssf_train_validate_example.ipynb in VSCode to get started. You can also view the knitted deepssf_train_validate_example.html script, which you should be able to open in a browser such as Chrome.


Documentation

There are additional tutorials and walkthroughs to help understand deep learning concepts and the deepSSF approach, model and functions at: 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.3.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.3-py3-none-any.whl (7.9 MB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: deepssf-0.2.3.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.3.tar.gz
Algorithm Hash digest
SHA256 f0354b95db6432eaa2a25edac46c970bc604f120c2e27c404b0bd8a957726e3d
MD5 b1118dc650ca7a4bdb21d99cf12ebbeb
BLAKE2b-256 5a84d1160a7862a6a60dcca7a66d9f02c3682f7cf07d86f298b03cdccf2a4b20

See more details on using hashes here.

Provenance

The following attestation bundles were made for deepssf-0.2.3.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.3-py3-none-any.whl.

File metadata

  • Download URL: deepssf-0.2.3-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.3-py3-none-any.whl
Algorithm Hash digest
SHA256 0f8dce9ad6f11c4fd1b7844d0ead17b5adbfa4f3e36821430c07a20558e7d703
MD5 21f06bdfc31cb3576fc619090b66272f
BLAKE2b-256 5ca51af4ef98f08619b4a93363b018c380e00a36320c13f72b6a6dee352049ee

See more details on using hashes here.

Provenance

The following attestation bundles were made for deepssf-0.2.3-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