Python Package for Empirical Statistical Downscaling. pyESD is under active development and all colaborators are welcomed. The purpose of the package is to downscale any climate variables e.g. precipitation and temperature using predictors from reanalysis datasets (eg. ERA5) to point scale. pyESD adopts many ML and AL as the transfer function.
Project description
Python Package for Empirical Statistical Downscaling (v1.01) :sun_behind_rain_cloud: :cloud_with_snow: :cloud_with_rain: :fire: :thermometer:
PyESD is an open-source framework of the Perfect Prognosis approach of statistical downscaling of any climate-related variable such as precipitation, temperature, and wind speed using reanalysis products eg. ERA5 as predictors. The package features all the downscaling cycles including data preprocessing, predictor selection, constructions (eg. using transformers), model selection, training, validation and evaluation, and future prediction. The package serves as the means of downscaling General Circulation Models of future climate to high resolution relevant for climate impact assessment such as droughts, flooding, wildfire risk, and others. The main specialties of the pyESD include:
- Well designed in an OOP style that considers weather stations as individual objects and all the downscaling routines as attributes. This ensures fewer lines of code that cover the end-to-end downscaling of climate change variable products.
- PyESD features many machine learning algorithms and predictor selection techniques that can be experimented with toward the selection and design of robust transfer functions that can be coupled with GCM to generate future estimates of climate change
- And many other functionalities that are highlighted in the paper description of the package (to be submitted).
The main component and the work flow of the package are summarised in the modeling outline:
Installation :hammer_and_wrench:
-
Install the standard version:
pip install pyESD
from PyPI or git clone git@github.com:Dan-Boat/PyESD.gitcd to the folder
|pip install .
-
Install in editable mode:
pip install -e pyESD
orpip install -e .
in the package base folder clone from github The installation might require some dependencies that must be installed if not successful from the distribution from PyPI: cartopy, xarray, sciki-learn, scipy and the other scientific frameworks such as NumPy, pandas, Matplotlib, and seaborn -
Alternatively, to ensure the installation in an isolated environment, virtual python environment using
conda
orvirtualenv
can be used to create a separate env for the package installation
Documentation :blue_book:
The package documentation is still in progress. The initial structure is accessible at github-pages
Examples
The package has been used for downscaling precipitation and temperature for a catchment located in southwestern Germnany. We have also used it for generating future rainfall products for all the synoptic weather stations in Ghana. Their respective control scripts are located in the examples folder. Generally, the control scripts follow the modeling workflow as shown in: . For instance, the downscaling framework show below can be experimented with to select the robust predictor selection method and emprical transfer function for a specific location and predictand variable.
Workflow demonstration: To use the PP-ESD model to downscale climate model, weather station and reanalysis datasets are required. The predictors are loaded in as netCDF files and the predictand as csv file. Let assume that the various predictor variables are stored locally in the era5_datadir
directory /home/daniel/ERA5/
and the predictand variable eg. precipitation is stored in station_dir
The files should have the same timestamp as the interested predictand variable
- import all the required modules
from pyESD.Weatherstation import read_station_csv
from pyESD.standardizer import MonthlyStandardizer, StandardScaling
from pyESD.ESD_utils import store_pickle, store_csv
from pyESD.splitter import KFold
from pyESD.ESD_utils import Dataset
from pyESD.Weatherstation import read_weatherstationnames
import pandas as pd
- Read the datasets
ERA5Data = Dataset('ERA5', {
't2m':os.path.join(era5_datadir, 't2m_monthly.nc'),
'msl':os.path.join(era5_datadir, 'msl_monthly.nc'),
'u10':os.path.join(era5_datadir, 'u10_monthly.nc'),
'v10':os.path.join(era5_datadir, 'v10_monthly.nc'),
'z250':os.path.join(era5_datadir, 'z250_monthly.nc'),
- define potential predictors and radius of predictor construction, time range for model training and evaluation
radius = 100 #km
predictors = ["t2m", "tp","msl", "v10", "u10"]
from1958to2010 = pd.date_range(start="1958-01-01", end="2010-12-31", freq="MS") #training and validation
from2011to2020 = pd.date_range(start="2011-01-01", end="2020-12-31", freq="MS") # testing trained data
- Read weather stations as objects and apply the downscaling cycle attributes. Note that running the model the first time for a specific location extract the regional means using the define radius and location of the station. The extracted means are stored in a pickel files in the directory called
predictor_dir
variable = "Precipitation"
SO = read_station_csv(filename=station_dir, varname=variable)
# USING ERA5 DATA
# ================
#setting predictors
SO.set_predictors(variable, predictors, predictordir, radius,)
#setting standardardizer
SO.set_standardizer(variable, standardizer=MonthlyStandardizer(detrending=False,
scaling=False))
scoring = ["neg_root_mean_squared_error",
"r2", "neg_mean_absolute_error"]
#setting model
regressor = "RandomForest"
SO.set_model(variable, method=regressor,
daterange=from1958to2010,
predictor_dataset=ERA5Data,
cv=KFold(n_splits=10),
scoring = scoring)
# MODEL TRAINING (1958-2000)
# ==========================
SO.fit(variable, from1958to2010, ERA5Data, fit_predictors=True, predictor_selector=True,
selector_method="Recursive" , selector_regressor="ARD",
cal_relative_importance=False)
score_1958to2010, ypred_1958to2010 = SO.cross_validate_and_predict(variable, from1958to2010, ERA5Data)
score_2011to2020 = SO.evaluate(variable, from2011to2020, ERA5Data)
ypred_1958to2010 = SO.predict(variable, from1958to2010, ERA5Data)
ypred_2011to2020 = SO.predict(variable, from2011to2020, ERA5Data)
ypred_2011to2020.plot()
plt.show()
Package testing
The package is tested using the unittest
framework with synthetic generated data. The testing scripts are located in the test folder. Running the various scripts with -v flag (higher level of verbose), would validate the modified version of the package.
Publications
The package description and application paper is currently under preparation (to be submitted to GMD) Its application for weather station in Ghana was presented at the AGU22 Link and the paper is under preparation
Citation: Upload on zenodo: https://doi.org/10.5281/zenodo.7748769
Future versions
The pacakage is still in planing stage (v.0.0.1) (The stable version would be uploaded on pypi with the version number v.1.0.1)
Collaborators are welcomed: interms of model application, model improvement, documentation and expansion of the package!
@ Daniel Boateng (linkedin) : University of Tuebingen :incoming_envelope: dannboateng@gmail.com
======= History
1.0.7 (2023-06-30)
Bug fixes
* Fix the issues with installation on pypi
New indicators
--------------
* added additional teleconnection indicies for Southern Hemisphere
* Test the framework with daily data but reqiure additional models like wet day classifiers
* missing data in the predictand values can be fill with the implemented impute methods
To do
------
* Extend the package to use spatial datasets
* Implement wet and dry day classifiers before model training
* implement the various calibration metric for daily data
* Add simple MOS method (quantile mapping)
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file pyESD-1.0.7.tar.gz
.
File metadata
- Download URL: pyESD-1.0.7.tar.gz
- Upload date:
- Size: 50.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.9.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | a1d6595188f14adeab28df96d4f66e3cf90431cb7603cc26b83c608ad255f68d |
|
MD5 | 1c4209af75410a087ebc1304be9647db |
|
BLAKE2b-256 | 2e9f562b84db14b909c4d8fa088569c368beca6b82c7613438befdf760c02dbb |
File details
Details for the file pyESD-1.0.7-py2.py3-none-any.whl
.
File metadata
- Download URL: pyESD-1.0.7-py2.py3-none-any.whl
- Upload date:
- Size: 59.3 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.9.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2a62ec4dd1112c655cbcc0fca3b975f61ae312c13ea1bf01d06c928c700c7ebf |
|
MD5 | 600611d0f93e1b1b9ad4124fa11c0e44 |
|
BLAKE2b-256 | dce4b5683bb97f218d6ddc53dc62075a806bf02c7d55f410316420940f971c64 |