Skip to main content

DISSTANS

Project description

The DISSTANS Python package

Welcome to the package repository for the Decomposition and Inference of Sources through Spatiotemporal Analysis of Network Signals (DISSTANS) toolbox.

With DISSTANS, you can:

  • Fit GNSS displacement (or any type of) timeseries using a variety of functional models. These range from common ones such as a polynomial, a sinusoid, or a logarithm, to more complex ones as logarithms with unknown timescales, modulated sinusoids, or dictionaries of splines.
  • Solve for model parameters using least squares with no regularization or using any of the L2, L1, and L0 norms. Spatial L0 allows to use expected spatial coherence in the data to improve local fits.
  • Take advantage of multiprocessor systems using multiple threads for the most computationally heavy steps.
  • Perform PCA/ICA-based common mode estimation and timeseries basis decomposition.
  • Clean data from outliers.
  • Visualize timeseries, network maps, dictionary scalograms, station motions, station observation availabilities, model parameter correlations, and more.
  • Manage databases of raw RINEX files, including availability plots.
  • Download GNSS timeseries from public sites.
  • Use catalogued seismic and maintenance events to inform the model setup.
  • Detect jumps in the data using a simple step detector.
  • Run the MIDAS algorithm.
  • Generate synthetic timeseries.
  • Load timeseries in JPL's .(t)series, UNR's .tenv3 and .kenv, and Japan's F5 .pos formats natively, or load standard NumPy and pandas data.
  • Calculate velocity, strain, and rotation fields.

All from within your Python shell, and everything in standard Python object-oriented programming style, allowing you to easily subclass existing code to suit your individual needs.

Documentation

A peer-reviewed study has been published (see Using and citing this work below) that explains the concept, inner workings, goals, and successes of DISSTANS in detail. You can find the final version here, and the accepted preprint here.

Furthermore, DISSTANS contains full code annotation, an API documentation, as well as tutorials and real-data examples that show the usage of the package.

The documentation can be found in the docs/ folder. It is hosted on GitHub publicly at tobiscode.github.io/disstans, but you can also read it locally, e.g., by running python -m http.server 8080 --bind 127.0.0.1 from with the documentation folder and then opening a browser.

Installation

The full installation instructions, including necessary prerequisites, can be found in the documentation.

If you're happy with a minimal installation (no local documentation, not suited for modifications, without experimental newest commits), then the short answer is:

# download the environment file
wget https://raw.githubusercontent.com/tobiscode/disstans/main/environment.yml
# create the environment, including all prerequisites
conda env create -f environment.yml
# activate the environment
conda activate disstans
# install DISSTANS from the Python Package Index (PyPI)
pip install disstans

Updating the code is then just:

pip install --upgrade disstans

Using and citing this work

Please note that this work is under a GPL-3.0 License.

If you're using this code or any parts of it, please cite the following study:

Köhne, T., Riel, B., & Simons, M. (2023). Decomposition and Inference of Sources through Spatiotemporal Analysis of Network Signals: The DISSTANS Python package. Computers & Geosciences, 170, 105247. DOI: 10.1016/j.cageo.2022.105247

You can find the accepted preprint here.

A poster introducing the code was presented at the AGU Fall Meeting 2021, you can find it here.

Acknowledgments

This code would not be possible without the work of others, such as:

  • The inspiration for this code, pygeodesy by Bryan V. Riel
  • The MIDAS code by Geoff Blewitt
  • The powerlaw noise generation code colorednoise by Felix Patzelt
  • The wrapper for the Okada elastic dislocation model okada_wrapper by Thomas Ben Thompson

Reporting bugs and getting involved

If you find a bug or have a question about the code, please raise an issue on GitHub. If you have any other comment, feedback, or suggestion, feel free to send me an email to tkoehne@caltech.edu. Similarly, if you want to contribute to any part of the code (functions, classes, documentation, examples, etc.), please send me an email - contributions of all kinds are always welcome!

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

disstans-2.2.tar.gz (203.7 kB view details)

Uploaded Source

Built Distribution

disstans-2.2-py3-none-any.whl (195.1 kB view details)

Uploaded Python 3

File details

Details for the file disstans-2.2.tar.gz.

File metadata

  • Download URL: disstans-2.2.tar.gz
  • Upload date:
  • Size: 203.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.0 CPython/3.12.3

File hashes

Hashes for disstans-2.2.tar.gz
Algorithm Hash digest
SHA256 fae568815e24e0319c8e785dbe31fab8a4f2e8e0539e7b3c9535cd1d67e81d30
MD5 b26929afde49820baedc1ff83309cf2a
BLAKE2b-256 9817eace329accd43af3ecceaa46311b02d0767c9383b37d80cc0fea2feacff1

See more details on using hashes here.

File details

Details for the file disstans-2.2-py3-none-any.whl.

File metadata

  • Download URL: disstans-2.2-py3-none-any.whl
  • Upload date:
  • Size: 195.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.0 CPython/3.12.3

File hashes

Hashes for disstans-2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 cbe79bf257c3bbd2680a0e36c5ed4f4f1bbac255d18219613832e5a6f1dad40a
MD5 a13739409d4d27cd27456650806b1930
BLAKE2b-256 0ce9003225a84aa62402946102d281f4816369b7b4e226f4740f7d06283ca2b1

See more details on using hashes here.

Supported by

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