Skip to main content

Fast, region-agnostic stochastic weather generation

Project description

swxg

swxg is a Python package for modern stochastic weather generation. It is suitable for any use case where traces of precipitation, temperature, and its internal variability across a single or multiple sites impact the model outcomes to be investigated. It expands on existing generators which are often designed for more niche applications like replicating weather regimes, downscaling global circulation models, or using weather as an intermediate step in determining flood or drought indices.

All that is needed to use swxg is a set of data with precipitation and temperature observations, one or more locations where the observations were collected, and a timestamp for each of the collected observations. swxg quickly generates arbitrarily-long sequences of monthly or daily weather variables that match the spatial and temporal correlations from input observations by:

  1. fitting observed precipitation individually to a (Gaussian mixture) hidden Markov model with 1 or more hidden states;
  2. fitting both observed precipitation and temperature with hydroclimatic copulas;
  3. sampling precipitation from its fit, disaggregating to finer resolution where necessary, and;
  4. conditionally sampling temperature from the sampled precipitation and its fit, disaggregating to finer resolution where necessary

Dependencies

The required dependencies to use swxg are:

  • Python >= 3.10
  • copulae >= 0.8
  • copulas >= 0.10, < 0.12
  • hmmlearn >= 0.3
  • matplotlib >= 3.8
  • numpy == 2.0
  • pandas >= 2.1
  • scikit-learn >= 1.4
  • scipy >= 1.15
  • statsmodels >= 0.14, < 0.15

Note that these required packages will be automatically downloaded when you install this package.

Installation

To install swxg from PyPI with pip:

pip install swxg

Alternatively, you can install from this repository:

git clone https://github.com/xthames/swxg.git
cd swxg
pip install .

Contributing, Reporting Issues, and Seeking Support

To contribute, please fork this repository and create your own branch. If you are unfamiliar with that process the corresponding documentation on how to do so from FirstContributions is a good place to start. To report issues and seek support, please use the GitHub Issues tab for this repository.

Important Links

If your work uses swxg, please cite:

Known Model Limitations

Because swxg is a semi-parametric model, the quality of the input dataset will be reflected in: (1) the confidence of the fits for precipitation and the copulas, and; (2) the resolution of the generated weather.

  1. To fit precipitation and the copulas swxg aggregates precipitation and temperature both annually and monthly, meaning that more complete years of input data will produce better fitting. A UserWarning will appear if you use fewer than 30 years of input data; another UserWarning will appear if more than 20 sites are considered. Fitting will still procede regardless, but it is strongly recommended to validate the precipitation and copula fitness through additional metrics if either condition is met.
  2. When generating weather swxg gives the option to determine its output resolution, either at the monthly or daily scale. How resolved the generated weather can be is determined by the input dataset: monthly inputs can be resolved to monthly outputs; daily inputs can be resolved to both daily and monthly outputs. A UserWarning will appear when trying to resolve daily outputs from monthly inputs. If attempted, the monthly resolution will output instead. Subdaily inputs are accepted but generating at the subdaily scale is not yet implemented, and so subdaily data is aggregated to daily.

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

swxg-0.4.1.tar.gz (492.8 kB view details)

Uploaded Source

Built Distribution

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

swxg-0.4.1-py3-none-any.whl (497.6 kB view details)

Uploaded Python 3

File details

Details for the file swxg-0.4.1.tar.gz.

File metadata

  • Download URL: swxg-0.4.1.tar.gz
  • Upload date:
  • Size: 492.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.11

File hashes

Hashes for swxg-0.4.1.tar.gz
Algorithm Hash digest
SHA256 b27ca41a112945b484094cf3ff0f917b08615c408dc84f7c8d5fe2c4b7d9df0c
MD5 6081337db56f724e73ae427243c82875
BLAKE2b-256 76d87bd611481d6d86ee751d6f07279872645b6011374c0584046012891fe0ce

See more details on using hashes here.

File details

Details for the file swxg-0.4.1-py3-none-any.whl.

File metadata

  • Download URL: swxg-0.4.1-py3-none-any.whl
  • Upload date:
  • Size: 497.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.11

File hashes

Hashes for swxg-0.4.1-py3-none-any.whl
Algorithm Hash digest
SHA256 9c90c3c7379cdf6b930276e04ab8edfe866ca60831a1f6db182471b461eb4f2d
MD5 fe9906e657bcfaec302958975e1151c4
BLAKE2b-256 20a9e69172242bc77acf8dd1f368f938f533678404c8430110591e6fe038f140

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