Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/GlacioHack/xdem
Analysis of digital elevation models (DEMs)
https://github.com/GlacioHack/xdem
coregistration dem digital-elevation-model error-analysis geostatistics gis python surface-elevation-data terrain-analysis uncertainty-quantification variogram
Last synced: 3 months ago
JSON representation
Analysis of digital elevation models (DEMs)
- Host: GitHub
- URL: https://github.com/GlacioHack/xdem
- Owner: GlacioHack
- License: mit
- Created: 2020-11-11T22:43:21.000Z (over 4 years ago)
- Default Branch: main
- Last Pushed: 2024-11-15T23:19:44.000Z (3 months ago)
- Last Synced: 2024-11-16T00:18:57.872Z (3 months ago)
- Topics: coregistration, dem, digital-elevation-model, error-analysis, geostatistics, gis, python, surface-elevation-data, terrain-analysis, uncertainty-quantification, variogram
- Language: Python
- Homepage: https://xdem.readthedocs.io/
- Size: 23.4 MB
- Stars: 145
- Watchers: 8
- Forks: 41
- Open Issues: 148
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
- cryosphere-links - xDEM - A Python module developed by glaciologists for handling DEMs: read/write, coregistration, volume change calculation etc. (Cryosphere - across all subspheres / Cryo Software)
README
# xDEM: robust analysis of DEMs in Python.
[data:image/s3,"s3://crabby-images/8a0c8/8a0c836827b774a22146833c015a434992ae51df" alt="Documentation Status"](https://xdem.readthedocs.io/en/latest/?badge=latest)
[data:image/s3,"s3://crabby-images/a9d7b/a9d7bebf3f0ca09bc5eddd90bbf713ba19884be8" alt="build"](https://github.com/GlacioHack/xdem/actions/workflows/python-tests.yml)
[data:image/s3,"s3://crabby-images/f1e44/f1e441300533ae994685866705d7b74be8cfe41d" alt="Conda Version"](https://anaconda.org/conda-forge/xdem)
[data:image/s3,"s3://crabby-images/2c35a/2c35ab8fc7e114ca9b13142c94da4bf18d06eeac" alt="Conda Platforms"](https://anaconda.org/conda-forge/xdem)
[data:image/s3,"s3://crabby-images/70b58/70b58f5e37c43cf4a386a37b1596cd2e8df45a17" alt="Conda Downloads"](https://anaconda.org/conda-forge/xdem)
[data:image/s3,"s3://crabby-images/af5c3/af5c36f761c5a6d893c29b4f31751e94de77ebad" alt="PyPI version"](https://badge.fury.io/py/xdem)
[data:image/s3,"s3://crabby-images/de578/de578478508b0b2c4b2af0fe46c9b01d2ffffc92" alt="Coverage Status"](https://coveralls.io/github/GlacioHack/xdem?branch=main)[data:image/s3,"s3://crabby-images/fbe1d/fbe1d2f89215b7589b3f89aa2112c2614f97d3b5" alt="Binder"](https://mybinder.org/v2/gh/GlacioHack/xdem/main)
[data:image/s3,"s3://crabby-images/65ea5/65ea56a782a92978a9d1c30ea7b56b2bd4e42d2a" alt="Pre-Commit"](https://github.com/pre-commit/pre-commit)
[data:image/s3,"s3://crabby-images/98647/986475842f2907062b79c4bb27fdd075d638e5b9" alt="Formatted with black"](https://github.com/python/black)
[data:image/s3,"s3://crabby-images/ae90a/ae90a1b17cdb458fe3d891a0e5eca828a68a1e69" alt="Checked with mypy"](http://mypy-lang.org/)
[data:image/s3,"s3://crabby-images/2b8ac/2b8ac0b40688968d026c257731b2e37213f350f1" alt="Imports: isort"](https://pycqa.github.io/isort/)**xDEM** is an open source project to develop a core Python package for the analysis of digital elevation models (DEMs).
It aims at **providing modular and robust tools for the most common analyses needed with DEMs**, including both geospatial
operations specific to DEMs and a wide range of 3D alignment and correction methods from published, peer-reviewed studies.
The core manipulation of DEMs (e.g., vertical alignment, terrain analysis) are **conveniently centered around a `DEM` class** (that, notably, re-implements all tools
of [gdalDEM](https://gdal.org/programs/gdaldem.html)). More complex pipelines (e.g., 3D rigid coregistration, bias corrections, filtering) are **built around
modular `Coreg`, `BiasCorr` classes that easily interface between themselves**. Finally, xDEM includes advanced
uncertainty analysis tools based on spatial statistics of [SciKit-GStat](https://scikit-gstat.readthedocs.io/en/latest/).Additionally, xDEM inherits many convenient functionalities from [GeoUtils](https://github.com/GlacioHack/geoutils) such as
**implicit loading**, **numerical interfacing** and **convenient object-based geospatial methods** to easily perform
the most common higher-level tasks needed by geospatial users (e.g., reprojection, cropping, vector masking). Through [GeoUtils](https://github.com/GlacioHack/geoutils), xDEM
relies on [Rasterio](https://github.com/rasterio/rasterio), [GeoPandas](https://github.com/geopandas/geopandas) and [Pyproj](https://github.com/pyproj4/pyproj)
for georeferenced calculations, and on [NumPy](https://github.com/numpy/numpy) and [Xarray](https://github.com/pydata/xarray) for numerical analysis. It allows easy access to
the functionalities of these packages through interfacing or composition, and quick inter-operability through object conversion.If you are looking for an accessible Python package to write the Python equivalent of your [GDAL](https://gdal.org/) command lines, or of your
[QGIS](https://www.qgis.org/en/site/) analysis pipeline **without a steep learning curve** on Python GIS syntax, xDEM is perfect for you! For more advanced
users, xDEM also aims at being efficient and scalable by supporting lazy loading and parallel computing (ongoing).## Documentation
For a quick start, full feature description or search through the API, see xDEM's documentation at: https://xdem.readthedocs.io.
## Installation
```bash
mamba install -c conda-forge xdem
```
See [mamba's documentation](https://mamba.readthedocs.io/en/latest/) to install `mamba`, which will solve your environment much faster than `conda`.## Citing methods implemented in the package
When using a method implemented in xDEM, please **cite both the package and the related study**:
Citing xDEM: [data:image/s3,"s3://crabby-images/ad89d/ad89d1e4a3aa4cb2282a171da7d8cd64263b68c0" alt="Zenodo"](https://zenodo.org/doi/10.5281/zenodo.4809697)
Citing the related study:
- **Coregistration**:
- Horizontal shift from aspect/slope relationship of *[Nuth and Kääb (2011)](https://doi.org/10.5194/tc-5-271-2011)*,
- Iterative closest point (ICP) of *[Besl and McKay (1992)](http://dx.doi.org/10.1109/34.121791)*,
- **Bias correction**:
- Along-track multi-sinusoidal noise by basin-hopping of *[Girod et al. (2017)](https://doi.org/10.3390/rs9070704)*,
- **Uncertainty analysis**:
- Heteroscedasticity and multi-range correlations from stable terrain of *[Hugonnet et al. (2022)](https://doi.org/10.1109/JSTARS.2022.3188922)*,
- **Terrain attributes**:
- Slope, aspect and hillshade of either *[Horn (1981)](http://dx.doi.org/10.1109/PROC.1981.11918)* or *[Zevenbergen and Thorne (1987)](http://dx.doi.org/10.1002/esp.3290120107)*,
- Profile, plan and maximum curvature of *[Zevenbergen and Thorne (1987)](http://dx.doi.org/10.1002/esp.3290120107)*,
- Topographic position index of *[Weiss (2001)](http://www.jennessent.com/downloads/TPI-poster-TNC_18x22.pdf)*,
- Terrain ruggedness index of either *[Riley et al. (1999)](http://download.osgeo.org/qgis/doc/reference-docs/Terrain_Ruggedness_Index.pdf)* or *[Wilson et al. (2007)](http://dx.doi.org/10.1080/01490410701295962)*,
- Roughness of *[Dartnell (2000)](http://dx.doi.org/10.14358/PERS.70.9.1081)*,
- Rugosity of *[Jenness (2004)](https://doi.org/10.2193/0091-7648(2004)032[0829:CLSAFD]2.0.CO;2)*,
- Fractal roughness of *[Taud et Parrot (2005)](https://doi.org/10.4000/geomorphologie.622)*.## Contributing
We welcome new contributions, and will happily help you integrate your own DEM routines into xDEM!
After discussing a new feature or bug fix in an issue, you can open a PR to xDEM with the following steps:
1. Fork the repository, make a feature branch and push changes.
2. When ready, submit a pull request from the feature branch of your fork to `GlacioHack/xdem:main`.
3. The PR will be reviewed by at least one maintainer, discussed, then merged.More details on [our contributing page](CONTRIBUTING.md).