Skip to main content

Suite of Hydrodynamic, topographic analysis, Landscape Evolution model and visualisation tools

Project description

Scabbard

Python package to design, use or visualise topographic analysis, landscape evolution models and hydro/morphodynamics simulations. Among other, home of GraphFlood (CPU and GPU) and CHONK. This framework is also building a GPU backend for general purpose landscape modeling.

Built on the shoulder of giants

scabbard started as a personal codebase and evolved toward a fully-fledge numerical Framework. It uses the robust and battle-tested scientific python stack (e.g. numpy, scipy, numba, ...) and geospatial python (e.g. rasterio, geopandas, libgdal, ...). It also relies on multiple domain-specific libraries to built a future-proof and community-compatible backend: libtopotoolbox and pytopotoolbox, fastscapelib, LSDTopoTool as well as my own collection of c++ and numba routines. All the GPU backends use taichi to ensure cross-platform/hardware compatibility and user-friendly code.

  • Free software: MIT license

How to install

pip install pyscabbard

As simple as that. Thanks to github actions allowing smooth CI, you do not have to compile anything yourself.

NOTE: pytopotoolbox official installation procedure is still WIP. I provide binary wheels within this project (./wheels/pytopotoolbox ). At first import, scabbard will provide instruction (i.e. a single command line to run).

Features

  • General geomorphic routines

  • Graphflood: Efficient hydrodynamic modelling, tailored for large scale. CPU and GPU version.

  • CHONK/trackscape/popscape: Long term Landscape Evolution Models.

Usage

Documentation is WIP and will be online soon

Credits

This package was created with Cookiecutter_ and the audreyr/cookiecutter-pypackage_ project template.

.. _Cookiecutter: https://github.com/audreyr/cookiecutter .. _audreyr/cookiecutter-pypackage: https://github.com/audreyr/cookiecutter-pypackage

======= History

0.0.16 (2025-01-16)

  • Updating some calls for legacy graphflood
  • Adding some steenbok routines (LEM, neighbouring)
  • Improving the geometry module
  • Improving CPU hillshading
  • minor fixes and additions

0.0.15 (2024-12-08)

  • Fixing the new import system for legacy graphflood
  • Renamed graphflood.py to legacy_graphflood.py

0.0.14 (2024-11-20)

  • Small fixes on the boundary condition helpers

0.0.13 (2024-11-20)

  • Adding an option for changing the exponent in Riverdale friction equation (e.g. migrating from manning to chezy)

0.0.12 (2024-11-20)

  • Adapting the install process to pip topotoolbox
  • Migrating to new ttb
  • Minor fixes and additions
  • Adding the start of a multi-backend unified graphflood interface

0.0.11 (2024-11-05)

  • Loads of minor fixes in the install process
  • Adding an hdf5 io/helper
  • Refactor part of the ray tracing 3D plotter
  • Adding orthographic projection

0.0.9 (2024-10-25)

  • More fixes on the setup process
  • Added a simple GPU ray tracing engine for 3D plots
  • Started a unified interface for graphflood

0.0.8 (2024-10-15)

  • Cleaning the install process
  • Removing problematic legacy imports
  • Trimming requirements
  • Deprecating older tools relying on packages I do not use anymore

0.0.5 - 0.0.7 (2024-10-15)

  • Total refactoring. As Simple as that.
  • scabbard is the main tool now, it uses multiple backends DAGGER, pytopotoolbox, fastscapelib, numba and taichi

0.0.3 - 0.0.4 (2023-10-23)

  • Fixing couple of bugs on the grid
  • Experimental support for DAGGER's experimental stuff
  • Adding environment object (WIP, future main structure)

0.0.2 (2023-07-31)

  • Adding drainage divide quick extraction tools
  • Fixing sea_level/Z0 stuff

0.0.1 (2023-07-25)

  • First release on PyPI.
  • Adding tools for quick river extraction
  • Started a big behind-the-scene refactoring and standardisation (invisible at top level)
  • Maintenance and bug fixes

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

pyscabbard-0.0.16.tar.gz (116.9 kB view details)

Uploaded Source

Built Distribution

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

pyscabbard-0.0.16-py2.py3-none-any.whl (169.5 kB view details)

Uploaded Python 2Python 3

File details

Details for the file pyscabbard-0.0.16.tar.gz.

File metadata

  • Download URL: pyscabbard-0.0.16.tar.gz
  • Upload date:
  • Size: 116.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.11.10

File hashes

Hashes for pyscabbard-0.0.16.tar.gz
Algorithm Hash digest
SHA256 3c183f3bda0eb2131286cf27dbafb5c35cbbb169bef5c7f046709cb8d346b35b
MD5 346ad1bf55543ca778c68838d021f231
BLAKE2b-256 6f6865dc2b69bd43443434aa96db380e7312570da336a1a1cb0906ae43a9466e

See more details on using hashes here.

File details

Details for the file pyscabbard-0.0.16-py2.py3-none-any.whl.

File metadata

  • Download URL: pyscabbard-0.0.16-py2.py3-none-any.whl
  • Upload date:
  • Size: 169.5 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.11.10

File hashes

Hashes for pyscabbard-0.0.16-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 0c7b6cbde1999ba1e9e3c2bb24635ac50cc1714f235a5ef9ad445a60ccb47d5f
MD5 a04872d6d8df7ca3a1c45e4d80777fd1
BLAKE2b-256 8d555671bf89467d16d2602a33e43a5449ee021ece0d0a1231d8d19df38d5d28

See more details on using hashes here.

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