Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Decision relevant metrics #1131

Draft
wants to merge 79 commits into
base: main
Choose a base branch
from
Draft
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
79 commits
Select commit Hold shift + click to select a range
29ba3a3
add test file
May 13, 2024
f1bcdeb
add driver script
May 13, 2024
8e30190
change import
May 13, 2024
743a7f9
add lib
May 13, 2024
bd01ff0
clean up and add todos
May 16, 2024
c5a18dd
add drcdm driver
May 16, 2024
75f7f23
add init
May 16, 2024
9d209a6
Merge branch 'main' of https://github.com/PCMDI/pcmdi_metrics into 10…
May 16, 2024
2d1c8b8
update sftlf
May 16, 2024
938bbcb
update sftlf
May 16, 2024
3f3cb7a
update stats
May 16, 2024
5e2c861
add param
May 16, 2024
df5d077
add README
May 16, 2024
1ba973d
add example
May 16, 2024
96e6066
add test info
May 16, 2024
c1eabfb
add temp ind
Jun 7, 2024
b31c6a0
swap for mean
Jun 7, 2024
66fc4c0
Merge branch 'main' of https://github.com/PCMDI/pcmdi_metrics into 10…
Jun 18, 2024
a564659
add tasmin
Jun 19, 2024
ec07141
add diags
Jun 19, 2024
aefa41c
chunks
Jun 19, 2024
a063971
refactor
Jun 20, 2024
1ca5563
refactor
Jun 20, 2024
f0e9830
refactor p2
Jun 20, 2024
2d2ec80
refactor p2
Jun 20, 2024
4ef2108
add params
Jun 20, 2024
3c45c22
fix annual tasmax mean
Jun 20, 2024
01b8bb4
added precipitation metrics
Jun 21, 2024
06b1419
Merge branch 'main' of https://github.com/PCMDI/pcmdi_metrics into 10…
Jun 28, 2024
a52a529
updates for runtime
Jun 28, 2024
3c86769
add all metrics calls
Jun 28, 2024
18c4557
get running
Jul 2, 2024
ec83cb6
add to nc
Jul 12, 2024
5fa8660
fix file name
Jul 12, 2024
8245bd6
add figures
Jul 13, 2024
9b216f8
add more tasmin
Jul 18, 2024
0db6a95
add more tasmin
Jul 18, 2024
b7dbd39
add mm thresh
Jul 19, 2024
ac714c7
update comments
Jul 23, 2024
8a20657
add T units
Jul 23, 2024
5b55583
refactor temp
Jul 25, 2024
3fecbdd
refactor temp
Jul 25, 2024
bf722c4
add cwd
Aug 1, 2024
dc4249b
add cwd
Aug 1, 2024
5e64f15
fix cal
acordonez Aug 2, 2024
b29f8fa
comment cwd
acordonez Aug 5, 2024
61b65eb
fix cwd
Aug 7, 2024
7e97fe8
add cdd
Aug 9, 2024
4237358
add cdd
Aug 9, 2024
03be5ea
uncomment quant
acordonez Aug 13, 2024
cbac332
fix return
acordonez Aug 13, 2024
4b555a7
fix xy vars and tasmin
acordonez Aug 22, 2024
25b4143
fix xy vars
acordonez Aug 22, 2024
84cc350
fix files
acordonez Aug 22, 2024
2ad1c2f
Merge branch 'main' into 1098_ao_drcdm
acordonez Sep 20, 2024
064fe72
fix bug
acordonez Sep 20, 2024
93d48e1
fix bug
acordonez Sep 20, 2024
1733c79
Merge branch 'main' into 1098_ao_drcdm
acordonez Oct 2, 2024
4107061
Merge branch 'main' into 1098_ao_drcdm
acordonez Oct 11, 2024
965b4a3
add pr 99p0
acordonez Sep 24, 2024
4833f38
add pr 99p0
acordonez Sep 24, 2024
d646a37
cleanup
acordonez Sep 24, 2024
fd870cc
add seasonal tasmin
acordonez Sep 24, 2024
24d1534
add wettest day 5 year
acordonez Oct 2, 2024
2e74b36
no land/sea mask
acordonez Oct 8, 2024
8e53d22
change quantiles
acordonez Oct 8, 2024
29c5df7
redo quantiles
acordonez Oct 11, 2024
3368032
Merge branch 'main' into 1098_ao_drcdm
acordonez Oct 28, 2024
6c65bd2
update land/sea mask
acordonez Oct 28, 2024
610e693
land/sea option
acordonez Oct 28, 2024
83863b0
Merge branch 'main' into 1098_ao_drcdm
acordonez Oct 30, 2024
c9ac942
Merge branch 'main' into 1098_ao_drcdm
acordonez Nov 15, 2024
cdfe9be
Merge branch 'main' into 1098_ao_drcdm
acordonez Nov 18, 2024
e6b1175
Merge branch 'main' into 1098_ao_drcdm
acordonez Nov 22, 2024
526c37f
Merge branch 'main' into 1098_ao_drcdm
acordonez Dec 11, 2024
849c25c
Merge branch 'main' into 1098_ao_drcdm
acordonez Dec 17, 2024
d66a0f9
update readme
acordonez Dec 17, 2024
34192c6
Update README.md
acordonez Dec 17, 2024
0ac598b
Update README.md
acordonez Dec 17, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
70 changes: 70 additions & 0 deletions pcmdi_metrics/drcdm/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,70 @@
# Decision Relevant Climate Data Metrics

# How to run:
Install the PCMDI Metrics Package.

Set up a parameter file with your model information. An example parameter file can be found at param/drcdm_param.py. See the Parameters section below for more information.

Run the decision relevant metrics driver using the following command:
```
drcdm_driver.py -p your_parameter_file.py
```

## Inputs
The Decision Relevant Metrics Driver works on daily gridded climate data. This package expects input netcdf files to be cf-compliant and on regular latitude/longitude grids. X and Y dimensions must be named "lon" and "lat", and the time dimension must be named "time". The input variables must be called "tasmax", "tasmin", or "pr". Input files must contain lat, lon, and time bounds.

## Land/Sea mask
Metrics should only be calculated over land, so users have the option to provide a land/sea mask if the ocean area are not already masked in the input data. If the land/sea mask contains fractional values, land will defined as grid cells where the land area percentage is between 50 and 100. Areas south of 50S will be masked out.

If available, users should provide the land/sea mask that accompanies their datasets. The mask variable in the land/sea mask file must be called "sftlf". If land/sea masks are not provided, there is an option to generate them on-the-fly using pcmdi_utils. If no mask is provided and --generate-sftlf is set to False, no masking will be done by the PMP.

## Parameters:
| Parameter | Definition |
--------------|-------------
| case_id | (str) Will be appended to the metrics_output_path if present. |
| model_list | (list) List of model names. |
| realization | (list) List of realizations. |
| vars | (list) List of variables: "pr", "tasmax", and/or "tasmin". |
| filename_template | (str) The template for the model file name. May contain placeholders %(variable), %(model), %(model_version), or %(realization) |
| test_data_path | (str) The template for the directory containing the model file. May contain placeholders %(variable), %(model), %(model_version), or %(realization) |
| sftlf_filename_template | (str) The template for the model land/sea mask file. May contain placeholders %(model), %(model_version), or %(realization). Takes precedence over --generate_sftlf |
| generate_sftlf | (bool) If true, generate a land/sea mask on the fly when the model or reference land/sea mask is not found. If false, no land/sea mask is applied. |
| metrics_output_path | (str) The directory to write output files to. |
| plots | (bool) True to save world map figures of mean metrics. |
| nc_out | (bool) True to save netcdf files (required for postprocessing). |
| msyear | (int) Start year for model data set. |
| meyear | (int) End year for model data set. |
| ModUnitsAdjust | (tuple) Provide information for units conversion. Uses format (flag (bool), operation (str), value (float), new units (str)). Operation can be "add", "subtract", "multiply", or "divide". For example, use (True, 'multiply', 86400, 'mm/day') to convert kg/m2/s to mm/day.|
| dec_mode | (str) Toggle how season containing December, January, and February is defined. "DJF" or "JFD". Default "DJF". |
| annual_strict | (bool) This only matters for rolling 5-day metrics. If True, only use data from within a given year in the 5-day means. If False, the rolling mean will include the last 4 days of the prior year. Default False. |
| drop_incomplete_djf | (bool) If True, don't include data from the first January/February and last December in the analysis. Default False. |
| shp_path | (str) path to shapefile. |
| attribute | (str) Attribute used to identify region (eg, column of attribute table). For example, "COUNTRY" in a shapefile of countries. |
| region_name | (str) Unique feature value of the region that occurs in the attribute given by "--attribute". Must match only one geometry in the shapefile. An example is "NORTH_AMERICA" under the attribute "CONTINENTS". |

## Key information

### Units
The temperature data must be provided in Fahrenheit. The ModUnitsAdjust parameter can be used to convert either Kelvin or Celsius units to Fahrenheit on-the-fly. See this example:

```
# Kelvin to Fahrenheit
ModUnitsAdjust = (True, 'KtoF', 0, 'F')

# Celsius to Fahrenheit
ModUnitsAdjust = (True, 'CtoF', 0, 'F')
```
Precipitation units must be provided in mm. ModUnitsAdjust can also be used as documented in the Parameters section to convert units such as kg/m2/s to mm.

### Regions
The most efficient way to get postprocessed metrics for multiple regions is to run the drcdm driver without any region subsetting (leave shp_path, attribute, and region_name unset). The regions can be applied during postprocessing.

# How to test:
Create a conda environment with pcmdi_metrics and xclim
In the PMP root directory use:
`pip install .`

Edit the metrics output path in pcmdi_metrics/drcdm/param/drcdm_param.py to be a location at which you have write permission.

To launch a run with the demo parameter file use:
`drcdm_driver.py -p pcmdi_metrics/drcdm/param/drcdm_param.py`
Empty file added pcmdi_metrics/drcdm/__init__.py
Empty file.
Loading
Loading