-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathpr_climatology.py
More file actions
50 lines (42 loc) · 1.84 KB
/
pr_climatology.py
File metadata and controls
50 lines (42 loc) · 1.84 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
"""Command line program for calculating the annual precipitation climatology"""
import pdb
import argparse
import numpy as np
import xarray as xr
import xclim as xc
import dask.diagnostics
import cmdline_provenance as cmdprov
dask.diagnostics.ProgressBar().register()
def main(args):
"""Run the program."""
ds = xr.open_mfdataset(args.infiles)
try:
ds = ds.drop_vars(['crs',])
except:
pass
if args.test_region:
ds = ds.sel({'lat': slice(-30, -25), 'lon': slice(130, 135)})
elif args.ausclip:
ds = ds.sel({'lat': slice(-44.5, -10), 'lon': slice(112, 156.25)})
ds['pr'] = xc.core.units.convert_units_to(ds['pr'], 'mm/day')
ds = ds.sel(time=slice(args.start_date, args.end_date))
ds_annual = ds.resample(time='YE').sum('time').mean('time')
ds_annual['pr'].attrs['units'] = 'mm/year'
ds_annual['pr'].attrs['long_name'] = 'Precipitation'
ds_annual['pr'].attrs['standard_name'] = 'precipitation_flux'
ds_annual.attrs = ds.attrs
ds_annual.attrs['history'] = cmdprov.new_log()
ds_annual.to_netcdf(args.outfile)
if __name__ == '__main__':
parser = argparse.ArgumentParser(
description=__doc__,
formatter_class=argparse.RawDescriptionHelpFormatter
)
parser.add_argument("infiles", type=str, nargs='*', help="input daily precipitation files")
parser.add_argument("start_date", type=str, help="start date in YYYY-MM-DD format")
parser.add_argument("end_date", type=str, help="end date in YYYY-MM-DD format")
parser.add_argument("outfile", type=str, help="output file name")
parser.add_argument("--ausclip", action="store_true", default=False, help="Clip lat and lon bounds to Australia")
parser.add_argument("--test_region", action="store_true", default=False, help="process a small test region")
args = parser.parse_args()
main(args)