Skip to main content

Reference implementation of Relative Utility Value (RUV) to quantify forecast value

Project description

RUVPY

Tests Coverage License Contributor Covenant DOI

Open Science infrastructure written in Python.

RUVPY is a library which can be used in your software to quantify the value of forecast information for decision-making.

It is a reference implementation of the Relative Utility Value (RUV) method, which is very flexible and can accommodate a wide range of decisions.

It includes a set of commonly used decision rules, utility functions, damage functions, and economic models. The implementation is sufficiently computationally efficient for most situations and parallelises timesteps over available CPU cores. By default, computations use a single core, but this can be increased via the parallel_nodes argument. The primary focus of this implementation is clarity and flexibility.

The scope is intentionally narrow and does not include any figure generation, data loading and saving, other metrics, or analysis functionality. These functions are intended to be implemented in a larger workflow or analysis pipeline which calls the main entry point of this library.

Publications

The method and software package are introduced in detail in the following publications. We suggest reading these to understand the context and motivation for the software.

Laugesen, Richard and Thyer, Mark and McInerney, David and Kavetski, Dmitri, Software Library to Quantify the Value of Forecasts for Decision-Making: Case Study on Sensitivity to Damages. http://dx.doi.org/10.2139/ssrn.5001881 (under review)

Laugesen, R., Thyer, M., McInerney, D., and Kavetski, D.: Flexible forecast value metric suitable for a wide range of decisions: application using probabilistic subseasonal streamflow forecasts, Hydrol. Earth Syst. Sci., 27, 873–893, https://doi.org/10.5194/hess-27-873-2023, 2023.

Installation

The package is available on PyPI and can be installed using pip:

pip install ruvpy

Documentation

Generated documentation is available at https://richardlaugesen.github.io/ruvpy/ruvpy/.

Examples

The package includes a set of examples corresponding to each figure in the publications noted above. These are all implemented as Jupyter notebooks in the examples directory.

Templates

RUV is designed to be tailored to the decision being evaluated. This may require the development of custom components to define the decision context in RUVPY. A set of templates to help you get started is included in templates directory.

Please consider contributing your new components to the repository to help others.

Development

The main package requires Python (>=3.10), NumPy, SciPy, and Pathos. The examples additionally require XArray, Pandas, Jupyter, and Matplotlib; the tests require Pytest and Statsmodels, and generating docs requires pdoc3.

All dependencies are defined in an included pyproject.toml file ready for use with Poetry or Setuptools.

For example, once Poetry is installed you can set up the environment with:

poetry install --with dev

You may spawn a new shell with the virtual environment using poetry shell, or simply prefix commands with poetry run. To run the unit tests:

poetry run pytest

To run the examples you'll need the optional examples dependencies. Install them and start Jupyter with:

poetry install -E examples
poetry run jupyter notebook

Regenerate documentation using:

poetry run pdoc --html --output-dir docs ruvpy --force

Attribution

This project is licensed under the Apache License 2.0, which allows free use, modification, and distribution of the code.

We would like to acknowledge and thank everyone who has help this project in various ways. Please see the CONTRIBUTORS file for a full list of individuals.

For proper citation of this project, please refer to the CITATION.cff file, which provides guidance on how to cite the software. Please also consider citing the publications listed above.

Code of conduct

We encourage you to contribute! Everyone interacting with this project is expected to follow the Code of Conduct.

Contact

Richard Laugesen (richard@laugesen.com.au)

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ruvpy-1.0.0.tar.gz (20.1 kB view details)

Uploaded Source

Built Distribution

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

ruvpy-1.0.0-py3-none-any.whl (31.8 kB view details)

Uploaded Python 3

File details

Details for the file ruvpy-1.0.0.tar.gz.

File metadata

  • Download URL: ruvpy-1.0.0.tar.gz
  • Upload date:
  • Size: 20.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.3 CPython/3.12.3 Linux/6.6.87.2-microsoft-standard-WSL2

File hashes

Hashes for ruvpy-1.0.0.tar.gz
Algorithm Hash digest
SHA256 886500077063372b2902d20d8848a0f791938d2335447266ba1b3657fd2159de
MD5 e8835573ece9212302ad23a66591e526
BLAKE2b-256 d467cdc860812783058d0a4493c73637fdcff1e634cf5541af3a270e3e166d9a

See more details on using hashes here.

File details

Details for the file ruvpy-1.0.0-py3-none-any.whl.

File metadata

  • Download URL: ruvpy-1.0.0-py3-none-any.whl
  • Upload date:
  • Size: 31.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.3 CPython/3.12.3 Linux/6.6.87.2-microsoft-standard-WSL2

File hashes

Hashes for ruvpy-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 48f2bebe5a58f7bbb629fabcc364d5af710c36a36001c1e9e848fbc8848998c3
MD5 a88e391d5e0c2d677127439056964b68
BLAKE2b-256 9c141c4ef3623fdeeccc3df2c0291cff09cc775c207b92889bf7fb1d57ba97eb

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