Skip to main content

Add a short description here!

Project description

https://github.com/TUW-GEO/pytesmo/workflows/Automated%20Tests/badge.svg?branch=master ReadTheDocs PyPI-Server Binder Project generated with PyScaffold

SMADI

Soil Moisture Anomaly Detection Indicators

This repository contributes to a visiting research activity within the framework of EUMETSAT HSAF, hosted by TU Wien, on the subject “development of workflows for climate normal and anomaly calculation for satellite soil moisture products”.

SMADI is a comprehensive workflow designed to compute climate normals and detect anomalies in satellite soil moisture data. The primary focus is on ASCAT surface soil moisture (SSM) products. By establishing the distribution of SSM for each period and location, SMADI computes climatology, or climate normals, and subsequently identifies anomalies.

The core objective of SMADI is to leverage these anomaly indicators to identify and highlight extreme events such as droughts and floods, providing valuable insights for environmental monitoring and management. Furthermore, the methods used apply to other meteorological variables, such as precipitation, temperature, and more.

Features

  • Data Reading: Read and preprocess the input data from Supported data sources.

  • Climatology: Compute the climatology for the input data based on different time steps (e.g., monthly, dekadal, weekly, etc.).

  • Anomaly Detection: Detect anomalies based on the computed climatology using different anomaly detection indices.

  • Visualization: Visualize the computed climatology and anomalies as time series, maps, and histograms.

Workflow Processing

The package installation through pip will enable a command-line entry point for calculating anomalies using one or more of the available methods across various dates. The command, named ‘smadi_run’, is designed to compute indices for the ASCAT gridded NetCDF datasets. This Python entry point is intended to be executed through a bash shell command:

smadi_run <positional arguments> <options>

For more information about the positional and optional arguments of this command, run:

smadi_run -h

Installation

User Installation

For users who simply want to use smadi, you can install it via pip:

pip install smadi
Developer Installation

If you’re a developer or contributor, follow these steps to set up smadi:

  1. Clone the repository:

git clone https://github.com/MuhammedM294/smadi
  1. Navigate to the cloned directory:

cd smadi
  1. Create and activate a virtual environment using Conda or virtualenv:

For Conda:

conda create --name smadi_env python=3.8
conda activate smadi_env

For virtualenv:

virtualenv smadi_env
source smadi_env/bin/activate  # On Unix or MacOS
.\smadi_env\Scripts\activate    # On Windows
  1. Install dependencies from requirements.txt:

pip install -r requirements.txt

Docker Usage

To use the Docker image for SMADI, follow these steps:

  1. Pull the Docker Image:

    Open your terminal and run the following command to pull the Docker image from Docker Hub:

    docker pull muhammedabdelaal/smadi:latest
  2. Run the Docker Image:

    After pulling the image, you can run it with the following command:

    docker run -it muhammedabdelaal/smadi:latest

    This will start a container with the SMADI application.

Note

This project has been set up using PyScaffold 4.5. For details and usage information on PyScaffold see https://pyscaffold.org/.

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

smadi-1.1.1.tar.gz (159.9 kB view hashes)

Uploaded Source

Built Distribution

smadi-1.1.1-py3-none-any.whl (27.8 kB view hashes)

Uploaded Python 3

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