Skip to main content

Compare meterological station data to gridded data

Project description

Build Coverage Documentation Status Downloads per month PyPI version


A package for comparing climate station time series data to gridMET (or other gridded) data. Major functionality includes tools to:

  • pair station locations with overlapping grid cells

  • download gridMET data from OpenDap server

  • calculate mean bias ratios between station and gridded data and other statistics

  • spatial interpolation of bias ratios with multiple interpolation options

  • build geo-referenced files of point data and interpolated rasters

  • extract zonal means for a subset of gridcells

  • graphics, e.g. time series comparisons and interpolated residuals at stations

Bias ratios calculated by gridwxcomp can be used to correct bias of grid to station data based on the properties of the stations. For example, monthly humidity ratios between station and grid for stations within agricultural settings can be used to estimate grid bias relative to agricultural locations. gridwxcomp includes an intuitive command line interface and a Python API.

Documentation

Online documentation

Installation

Currently we recommend using the provided conda environment file to install gridwxcomp and its dependencies in a virtual environment. Download the environment.yml file and then install and activate it. If you don’t have conda get it here. To install dependencies in a virtual environment run

$ conda env create -f environment.yml

To activate the environment before using gridwxcomp run

$ conda activate gridwxcomp

Optionally, install using pip,

$ pip install gridwxcomp

Due to dependency conflicts you may have issues directly installing with pip before activating the conda environment.

Alternatively, or if there are installation issues, you can manually install. First activate the gridwxcomp conda environment (above). Next, clone or download the package from GitHub or PyPI and then install locally with pip in “editable” mode. For example with cloning,

$ git clone https://github.com/WSWUP/gridwxcomp.git
$ cd gridwxcomp
$ pip install -e .

If you downloaded the source distribution then run pip install -e . in the root directory where the setup.py file is located. This installation method is ideal if you want to be able to modify the source code.

Quick start from command line

This example uses data provided with gridwxcomp including climate variable time series data for four climate stations, it uses the gridMET as the gridded dataset however any uniform gridded data product can be used with gridwxcomp if extra information including a vector grid file is provided.

After installation you can find the location of the data needed for the example by typing the following at the command line,

$ python -c "import pkg_resources; print(pkg_resources.resource_filename('gridwxcomp', 'example_data/Station_Data.txt'))"

Once complete, this example will calculate bias ratios between station and gridMET ETr (reference evapotranspiration), spatially interpolate GeoTIFF rasters of bias ratios at 400 meter resolution, and calculate zonal statistics of mean bias ratios for each gridMET cell in the region of the stations, similar to what is shown in the figure below.

https://raw.githubusercontent.com/WSWUP/gridwxcomp/master/docs/source/_static/test_case.png

The same procedure can be done for climate variables other than ETr, e.g. observed evapotranspiration, temperature, precipitation, wind speed, short wave radiation, etc.

After installing with pip the gridwxcomp command line interface can be used from any directory, the first step pairs climate station data with their nearest gridMET cell and produces a CSV file used in the following steps,

$ gridwxcomp prep-input <PATH_TO example_data/Station_Data.txt>

This will result in the file “merged_input.csv”. Next download matching gridMET climate time series with OpeNDAP by running

$ gridwxcomp download-gridmet-opendap merged_input.csv -y 2016-2017

The time series of gridMET data that correpond with the stations in “merged_input.csv” will be saved to a new folder called “gridmet_data” by default. In this case only the years 2016-2017 are used.

Next, to calculate mean monthly and annual bias ratios for each station/gridMET pair along with other statistics and metadata and save to CSV files,

$ gridwxcomp calc-bias-ratios merged_input.csv -o monthly_ratios

Last, to calculate interpolated surfaces of mean bias ratios and extract zonal means to gridMET cells using the default interpolation method (inverse distance weighting):

$ gridwxcomp spatial monthly_ratios/etr_mm_summary_comp_all_yrs.csv -b 5

The [-b 5] option indicates that we want to expand the rectangular bounding area for interpolation by five gridMET cells (extrapolation in the outer regions).

GeoTIFF rasters of interpolated ratios will be saved to “monthly_ratios/spatial/etr_mm_invdist_400m/”. Note, the gridMET variable name (etr_mm), the interpolation method (invdist), and the raster resolution (400m) are specified in the output directory. A fishnet grid with gridMET id values and a point shapefile of station ratios should all be created and saved in the “monthly_ratios/spatial/” directory.

The output file “monthly_ratios/spatial/etr_mm_invdist_400m/gridMET_stats.csv” contains monthly bias ratios for each gridMET cell in the interpolation region, similar to what is shown below.

GRIDMET_ID

Jan_mean

Feb_mean

Mar_mean

515902

0.66

0.76

0.96

514516

0.66

0.77

0.96

513130

0.67

0.77

0.97

511744

0.67

0.78

0.97

510358

0.68

0.79

0.97

Note GRIDMET_ID is the index of the master gridMET dataset 4 km fishnet grid starting at 0 in the upper left corner and moving across rows and down columns. This value can be joined with previously created data, e.g. the ID values can be joined to centroid coordinates of gridMET cells.

Bar plots that show the residual between station mean ratios and interpolated estimates are saved to “monthly_ratios/spatial/etr_mm_invdist_400m/residual_plots/”.

To get abbreviated descriptions for any of the above gridwxcomp commands use the [--help] option, e.g.

$ gridwxcomp spatial --help

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

gridwxcomp-0.1.2.tar.gz (1.6 MB view details)

Uploaded Source

Built Distribution

gridwxcomp-0.1.2-py2.py3-none-any.whl (12.2 MB view details)

Uploaded Python 2Python 3

File details

Details for the file gridwxcomp-0.1.2.tar.gz.

File metadata

  • Download URL: gridwxcomp-0.1.2.tar.gz
  • Upload date:
  • Size: 1.6 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.11.0 pkginfo/1.4.2 requests/2.19.1 setuptools/40.1.0 requests-toolbelt/0.8.0 tqdm/4.24.0 CPython/3.6.9

File hashes

Hashes for gridwxcomp-0.1.2.tar.gz
Algorithm Hash digest
SHA256 71f0c4c3afeb67e8c90d1b9b8b584175bc9e6d96ddc115a66e878d4bdb7655be
MD5 9fe8a6497989e22f935cefc45dfb3e2f
BLAKE2b-256 47139fbf29bfdc6081544f7fbcdb918a8701d6f2c5290ad5b6f3468b2624d920

See more details on using hashes here.

File details

Details for the file gridwxcomp-0.1.2-py2.py3-none-any.whl.

File metadata

  • Download URL: gridwxcomp-0.1.2-py2.py3-none-any.whl
  • Upload date:
  • Size: 12.2 MB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.11.0 pkginfo/1.4.2 requests/2.19.1 setuptools/40.1.0 requests-toolbelt/0.8.0 tqdm/4.24.0 CPython/3.6.9

File hashes

Hashes for gridwxcomp-0.1.2-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 61b2029b5e3541cd19cb8465f59e8eba0bd9ab86557b9be5120a80dbb40f6cbf
MD5 bfa88014d79a579df1accec1735bb548
BLAKE2b-256 70dcb5c6061da83cf0b48554f37ebfd5ca77ae7e54e6caeec261876728e8a5e5

See more details on using hashes here.

Supported by

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