7. Precipitation Variability Across Timescales

This notebook demonstrates how to use the precipitation variability metrics driver and calc_ratio script to obtain the precipitation variability metric.

Our metric is based on the simulated-to-observed ratio of spectral power because the spectral power is substantially sensitive to the processing choices for power spectra analysis (e.g., window length, overlap length, and windowing function). By using the ratio, the metric is not greatly affected by the different processing choices, helping the robustness of analysis results.

This notebook should be run in an environment with python, jupyterlab, pcmdi metrics package, and cdat installed. It is expected that you have downloaded the sample data as demonstrated in the download notebook.

Reference

  • Ahn, M.-S., P. J. Gleckler, J. Lee, A. G. Pendergrass, and C. Jakob, 2022: Benchmarking Simulated Precipitation Variability across Timescales. Journal of Climate, 35, 3173–3196, doi: 10.1175/JCLI-D-21-0542.1

  • Lee, J., P. J. Gleckler, M.-S. Ahn, A. Ordonez, P. Ullrich, K. R. Sperber, K. E. Taylor, Y. Y. Planton, E. Guilyardi, P. Durack, C. Bonfils, M. D. Zelinka, L.-W. Chao, B. Dong, C. Doutriaux, C. Zhang, T. Vo, J. Boutte, M. F. Wehner, A. G. Pendergrass, D. Kim, Z. Xue, A. T. Wittenberg, and J. Krasting, 2024: Systematic and Objective Evaluation of Earth System Models: PCMDI Metrics Package (PMP) version 3. Geoscientific Model Development, 17, 3919–3948, doi: 10.5194/gmd-17-3919-2024

The following cell reads in the choices you made during the download data step:

[1]:
from user_choices import demo_data_directory, demo_output_directory

Basic Use

Help

Use the --help flag for assistance with the precip variability driver:

[2]:
%%bash
variability_across_timescales_PS_driver.py --help
usage: variability_across_timescales_PS_driver.py [-h]
                                                  [--parameters PARAMETERS]
                                                  [--diags OTHER_PARAMETERS [OTHER_PARAMETERS ...]]
                                                  [--mip MIP] [--exp EXP]
                                                  [--mod MOD] [--var VAR]
                                                  [--frq FRQ]
                                                  [--modpath MODPATH]
                                                  [--results_dir RESULTS_DIR]
                                                  [--case_id CASE_ID]
                                                  [--prd PRD [PRD ...]]
                                                  [--fac FAC]
                                                  [--nperseg NPERSEG]
                                                  [--noverlap NOVERLAP]
                                                  [--ref REF] [--res RES]
                                                  [--regions_specs REGIONS_SPECS]
                                                  [--cmec] [--no_cmec]
                                                  [--region_file REGION_FILE]
                                                  [--feature FEATURE]
                                                  [--attr ATTR]

options:
  -h, --help            show this help message and exit
  --parameters PARAMETERS, -p PARAMETERS
  --diags OTHER_PARAMETERS [OTHER_PARAMETERS ...], -d OTHER_PARAMETERS [OTHER_PARAMETERS ...]
                        Path to other user-defined parameter file. (default:
                        None)
  --mip MIP             cmip5, cmip6 or other mip (default: None)
  --exp EXP             amip, cmip or others (default: None)
  --mod MOD             model (default: None)
  --var VAR             pr or other variable (default: None)
  --frq FRQ             day, 3hr or other frequency (default: None)
  --modpath MODPATH     data directory path (default: None)
  --results_dir RESULTS_DIR
                        results directory path (default: None)
  --case_id CASE_ID     case_id with date (default: None)
  --prd PRD [PRD ...]   start- and end-year for analysis (e.g., 1985 2004)
                        (default: None)
  --fac FAC             factor to make unit of [mm/day] (default: None)
  --nperseg NPERSEG     length of segment in power spectra (default: None)
  --noverlap NOVERLAP   length of overlap between segments in power spectra
                        (default: None)
  --ref REF             reference data path (default: None)
  --res RES             Horizontal resolution [degree] for interpolation (lon,
                        lat) (default: 2)
  --regions_specs REGIONS_SPECS
                        Provide a single custom region (default: None)
  --cmec                Use to save CMEC format metrics JSON (default: False)
  --no_cmec             Do not save CMEC format metrics JSON (default: False)
  --region_file REGION_FILE
                        File containing vector region of interest. (default:
                        None)
  --feature FEATURE     Feature in vectorized region. (default: None)
  --attr ATTR           Attribute containing feature in vectorized region.
                        (default: None)

Parameter file

Settings can be specified in a parameter file or on the command line. The basic case demonstrated here uses a parameter file, which is printed below.

Note that this driver should only be used to run one model or dataset at a time.

The mod variable can either be set to a particular file name, as shown here, or to a model name (i.e. “GISS-E2-H”).

[3]:
# print parameter file
with open("basic_precip_variability_param.py") as f:
    print(f.read())
mip = "cmip5"
exp = "historical"
mod = "pr_day_GISS-E2-H_historical_r6i1p1_*.nc"
var = "pr"
frq = "day"
modpath = 'demo_data_tmp/CMIP5_demo_timeseries/historical/atmos/day/pr/'
results_dir = 'demo_output_tmp/precip_variability/GISS-E2-H/'
prd = [2000,2005]  # analysis period
fac = 86400  # factor to make unit of [mm/day]

# length of segment in power spectra (~10 years)
# shortened to 2 years for demo purposes
nperseg = 2 * 365
# length of overlap between segments in power spectra (~5 years)
# shortened to 1 year for demo purposes
noverlap = 1 * 365

# flag for cmec formatted JSON
cmec = False

Running the driver

The parameter file is passed to the driver using the -p flag, similar to other PMP metrics. The basic command is:
variability_across_timescales_PS_driver.py -p parameter_file_name.py

The next cell uses the command line syntax to execute the driver as a subprocess.

[4]:
%%bash
variability_across_timescales_PS_driver.py -p basic_precip_variability_param.py
demo_data_tmp/CMIP5_demo_timeseries/historical/atmos/day/pr/
pr_day_GISS-E2-H_historical_r6i1p1_*.nc
[2000, 2005]
730 365
2
demo_output_tmp/precip_variability/GISS-E2-H/
demo_output_tmp/precip_variability/GISS-E2-H/
demo_output_tmp/precip_variability/GISS-E2-H/
['demo_data_tmp/CMIP5_demo_timeseries/historical/atmos/day/pr/pr_day_GISS-E2-H_historical_r6i1p1_20000101-20051231.nc']
GISS-E2-H.r6i1p1
['demo_data_tmp/CMIP5_demo_timeseries/historical/atmos/day/pr/pr_day_GISS-E2-H_historical_r6i1p1_20000101-20051231.nc']
GISS-E2-H.r6i1p1 365_day
2000 2005
Complete regridding from (2190, 90, 144) to (2190, 90, 180)
/Users/lee1043/mambaforge/envs/pmp_devel_20241106_xcdat0.7.3/lib/python3.10/site-packages/pcmdi_metrics/precip_variability/lib/lib_variability_across_timescales.py:341: FutureWarning: 'H' is deprecated and will be removed in a future version, please use 'h' instead.
  climtime = pd.period_range(
Complete calculating climatology and anomaly for calendar of 365_day
Complete power spectra (segment:  730  nps: 5.0 )
Complete domain and frequency average of spectral power
Complete power spectra (segment:  730  nps: 5.0 )
Complete domain and frequency average of spectral power
INFO::2024-11-20 16:44::pcmdi_metrics:: Results saved to a json file: /Users/lee1043/Documents/Research/git/pcmdi_metrics_20230620_pcmdi/pcmdi_metrics/doc/jupyter/Demo/demo_output_tmp/precip_variability/GISS-E2-H/PS_pr.day_regrid.180x90_area.freq.mean_GISS-E2-H.r6i1p1.json
2024-11-20 16:44:17,468 [INFO]: base.py(write:422) >> Results saved to a json file: /Users/lee1043/Documents/Research/git/pcmdi_metrics_20230620_pcmdi/pcmdi_metrics/doc/jupyter/Demo/demo_output_tmp/precip_variability/GISS-E2-H/PS_pr.day_regrid.180x90_area.freq.mean_GISS-E2-H.r6i1p1.json
2024-11-20 16:44:17,468 [INFO]: base.py(write:422) >> Results saved to a json file: /Users/lee1043/Documents/Research/git/pcmdi_metrics_20230620_pcmdi/pcmdi_metrics/doc/jupyter/Demo/demo_output_tmp/precip_variability/GISS-E2-H/PS_pr.day_regrid.180x90_area.freq.mean_GISS-E2-H.r6i1p1.json

Results

Running the precipitation variability driver produces three output files, found in the demo output directory:

Spatial pattern of spectral power (forced variability) (netCDF)
Spatial pattern of spectral power (unforced variability) (netCDF)
Average of spectral power (forced and unforced) (JSON)
[5]:
!ls {demo_output_directory + "/precip_variability/GISS-E2-H"}
PS_pr.day_regrid.180x90_GISS-E2-H.r6i1p1.nc
PS_pr.day_regrid.180x90_GISS-E2-H.r6i1p1_unforced.nc
PS_pr.day_regrid.180x90_area.freq.mean_GISS-E2-H.r6i1p1.json

The next cell displays the metrics from the JSON file.

[6]:
import json
import os
output_path = os.path.join(demo_output_directory,"precip_variability/GISS-E2-H/PS_pr.day_regrid.180x90_area.freq.mean_GISS-E2-H.r6i1p1.json")
with open(output_path) as f:
    metric = json.load(f)["RESULTS"]
print(json.dumps(metric, indent=2))
{
  "GISS-E2-H.r6i1p1": {
    "forced": {
      "Land_30N50N": {
        "annual": 1.153948602189099,
        "semi-annual": 0.36753810673147785
      },
      "Land_30S30N": {
        "annual": 6.850995810074617,
        "semi-annual": 1.1945015595812933
      },
      "Land_50S30S": {
        "annual": 0.8090939740005697,
        "semi-annual": 0.3429734614816379
      },
      "Land_50S50N": {
        "annual": 4.793570167683028,
        "semi-annual": 0.8971106124805723
      },
      "Ocean_30N50N": {
        "annual": 1.4501261513182653,
        "semi-annual": 0.3738726067518908
      },
      "Ocean_30S30N": {
        "annual": 4.561426422605005,
        "semi-annual": 1.5069884231014559
      },
      "Ocean_50S30S": {
        "annual": 0.5890515819402313,
        "semi-annual": 0.19150748548003432
      },
      "Ocean_50S50N": {
        "annual": 3.3050864193776075,
        "semi-annual": 1.0780758057454571
      },
      "Total_30N50N": {
        "annual": 1.3110986682307924,
        "semi-annual": 0.37089915519539457
      },
      "Total_30S30N": {
        "annual": 5.155704413930353,
        "semi-annual": 1.4258796929688173
      },
      "Total_50S30S": {
        "annual": 0.6055533541116589,
        "semi-annual": 0.20286646501256045
      },
      "Total_50S50N": {
        "annual": 3.6979701926949504,
        "semi-annual": 1.0303102268132056
      }
    },
    "unforced": {
      "Land_30N50N": {
        "interannual": 0.1102511231263155,
        "seasonal-annual": 0.1502570664470807,
        "sub-seasonal": 0.13618888930844547,
        "synoptic": 0.06327297649960476
      },
      "Land_30S30N": {
        "interannual": 0.3153529794234607,
        "seasonal-annual": 0.3117985429131878,
        "sub-seasonal": 0.24779678971270186,
        "synoptic": 0.07648497908010148
      },
      "Land_50S30S": {
        "interannual": 0.1617854187098499,
        "seasonal-annual": 0.21589364787265297,
        "sub-seasonal": 0.18475578606585347,
        "synoptic": 0.07524240453524902
      },
      "Land_50S50N": {
        "interannual": 0.24443780233758708,
        "seasonal-annual": 0.25718039033897055,
        "sub-seasonal": 0.21022029994683689,
        "synoptic": 0.07234360585017188
      },
      "Ocean_30N50N": {
        "interannual": 0.1326562564321627,
        "seasonal-annual": 0.1758330640897642,
        "sub-seasonal": 0.15435681112427357,
        "synoptic": 0.09817499779028159
      },
      "Ocean_30S30N": {
        "interannual": 0.6539803811119569,
        "seasonal-annual": 0.638536454370767,
        "sub-seasonal": 0.43424291163472356,
        "synoptic": 0.11428977945404167
      },
      "Ocean_50S30S": {
        "interannual": 0.09747609150424465,
        "seasonal-annual": 0.13244482423836876,
        "sub-seasonal": 0.11915711328928646,
        "synoptic": 0.06874014945078893
      },
      "Ocean_50S50N": {
        "interannual": 0.46727869921587156,
        "seasonal-annual": 0.4701741107777082,
        "sub-seasonal": 0.3304475909302172,
        "synoptic": 0.10233245216785036
      },
      "Total_30N50N": {
        "interannual": 0.12213915511604334,
        "seasonal-annual": 0.16382754040922717,
        "sub-seasonal": 0.1458286817964043,
        "synoptic": 0.08179178377228863
      },
      "Total_30S30N": {
        "interannual": 0.5660866430210981,
        "seasonal-annual": 0.553728738660788,
        "sub-seasonal": 0.385849171120644,
        "synoptic": 0.10447720904161918
      },
      "Total_50S30S": {
        "interannual": 0.10229887976839763,
        "seasonal-annual": 0.13870295233220017,
        "sub-seasonal": 0.12407659422553331,
        "synoptic": 0.06922777699836992
      },
      "Total_50S50N": {
        "interannual": 0.4084600708535097,
        "seasonal-annual": 0.41395463463349685,
        "sub-seasonal": 0.29871371960574505,
        "synoptic": 0.0944169266458939
      }
    }
  }
}

Command line usage with Obs data

To calculate the precipitation variability spectral power ratio, we also need results for a reference dataset. This example shows how to call the variability_across_timescales_PS_driver using a combination of the parameter file and command line arguments with daily observational data. The command line arguments will overwrite values that are in the parameter file.

The modpath and results_dir values are set first in a separate cell to easily combine the demo_data_directory and demo_output_directory variables with other strings. The new variables are then passed to the shell command in the second cell.

[7]:
modpath = demo_data_directory + '/obs4MIPs_PCMDI_daily/NASA-JPL/GPCP-1-3/day/pr/gn/latest/'
results_dir = demo_output_directory + '/precip_variability/GPCP-1-3/'
[8]:
%%bash -s "$modpath" "$results_dir"
variability_across_timescales_PS_driver.py -p basic_precip_variability_param.py \
--mip 'obs' \
--mod 'pr_day_GPCP-1-3_PCMDI_gn_19961002-20170101.nc' \
--modpath $1 \
--results_dir $2 \
--prd 1997 2016
demo_data/obs4MIPs_PCMDI_daily/NASA-JPL/GPCP-1-3/day/pr/gn/latest/
pr_day_GPCP-1-3_PCMDI_gn_19961002-20170101.nc
[1997, 2016]
730 365
2
demo_output/precip_variability/GPCP-1-3/
demo_output/precip_variability/GPCP-1-3/
demo_output/precip_variability/GPCP-1-3/
['demo_data/obs4MIPs_PCMDI_daily/NASA-JPL/GPCP-1-3/day/pr/gn/latest/pr_day_GPCP-1-3_PCMDI_gn_19961002-20170101.nc']
GPCP-1-3
['demo_data/obs4MIPs_PCMDI_daily/NASA-JPL/GPCP-1-3/day/pr/gn/latest/pr_day_GPCP-1-3_PCMDI_gn_19961002-20170101.nc']
GPCP-1-3 gregorian
1997 2016
Complete regridding from (7305, 180, 360) to (7305, 90, 180)
/Users/lee1043/mambaforge/envs/pmp_devel_20241106_xcdat0.7.3/lib/python3.10/site-packages/pcmdi_metrics/precip_variability/lib/lib_variability_across_timescales.py:341: FutureWarning: 'H' is deprecated and will be removed in a future version, please use 'h' instead.
  climtime = pd.period_range(
Complete calculating climatology and anomaly for calendar of gregorian
Complete power spectra (segment:  730  nps: 19.0 )
Complete domain and frequency average of spectral power
Complete power spectra (segment:  730  nps: 19.0 )
Complete domain and frequency average of spectral power
INFO::2024-11-20 16:47::pcmdi_metrics:: Results saved to a json file: /Users/lee1043/Documents/Research/git/pcmdi_metrics_20230620_pcmdi/pcmdi_metrics/doc/jupyter/Demo/demo_output/precip_variability/GPCP-1-3/PS_pr.day_regrid.180x90_area.freq.mean_GPCP-1-3.json
2024-11-20 16:47:38,470 [INFO]: base.py(write:422) >> Results saved to a json file: /Users/lee1043/Documents/Research/git/pcmdi_metrics_20230620_pcmdi/pcmdi_metrics/doc/jupyter/Demo/demo_output/precip_variability/GPCP-1-3/PS_pr.day_regrid.180x90_area.freq.mean_GPCP-1-3.json
2024-11-20 16:47:38,470 [INFO]: base.py(write:422) >> Results saved to a json file: /Users/lee1043/Documents/Research/git/pcmdi_metrics_20230620_pcmdi/pcmdi_metrics/doc/jupyter/Demo/demo_output/precip_variability/GPCP-1-3/PS_pr.day_regrid.180x90_area.freq.mean_GPCP-1-3.json

Precipitation Variability Metric

The precipitation variability metric can be generated after model and observational spectral averages are made.

A script called “calc_ratio.py” is provided in the precip_variability codebase. This script can be called with three arguments to generate the ratio.
ref: path to obs results JSON
modpath: directory containing model results JSONS (not CMEC formatted JSONs)
results_dir: directory for calc_ratio.py results

This script can be accessed via the PMP repo, which is how it is run here. It does not come with the PMP conda installation.

[9]:
%%bash -s "$demo_output_directory"
python ../../../pcmdi_metrics/precip_variability/scripts_pcmdi/calc_ratio.py \
--ref $1/precip_variability/GPCP-1-3/PS_pr.day_regrid.180x90_area.freq.mean_GPCP-1-3.json \
--modpath $1/precip_variability/GISS-E2-H/ \
--results_dir $1/precip_variability/ratio/
reference:  demo_output/precip_variability/GPCP-1-3/PS_pr.day_regrid.180x90_area.freq.mean_GPCP-1-3.json
modpath:  demo_output/precip_variability/GISS-E2-H/
outdir:  demo_output/precip_variability/ratio/
['demo_output/precip_variability/GISS-E2-H/PS_pr.day_regrid.180x90_area.freq.mean_GISS-E2-H.r6i1p1.json']
Complete  GISS-E2-H.r6i1p1
Complete all

This outputs one JSON file in the results_dir folder. The results in this file are shown below.

[10]:
output_path = os.path.join(demo_output_directory,"precip_variability/ratio/PS_pr.day_regrid.180x90_area.freq.mean_GISS-E2-H.r6i1p1.json")
with open(output_path) as f:
    metric = json.load(f)["RESULTS"]
print(json.dumps(metric, indent=2))
{
  "GISS-E2-H.r6i1p1": {
    "forced": {
      "Land_30N50N": {
        "annual": 1.6279984575673907,
        "semi-annual": 1.8670573736014953
      },
      "Land_30S30N": {
        "annual": 1.3338114720532628,
        "semi-annual": 1.333350181560795
      },
      "Land_50S30S": {
        "annual": 1.164227264547648,
        "semi-annual": 1.9246852085563546
      },
      "Land_50S50N": {
        "annual": 1.3503132388688284,
        "semi-annual": 1.3917495667061235
      },
      "Ocean_30N50N": {
        "annual": 1.052486197277382,
        "semi-annual": 0.8517712548298381
      },
      "Ocean_30S30N": {
        "annual": 1.499118828822202,
        "semi-annual": 1.8222593026548148
      },
      "Ocean_50S30S": {
        "annual": 1.4363958284724372,
        "semi-annual": 1.0484119422307991
      },
      "Ocean_50S50N": {
        "annual": 1.4625476582104207,
        "semi-annual": 1.6902905191733495
      },
      "Total_30N50N": {
        "annual": 1.2324909366302752,
        "semi-annual": 1.1401718517572579
      },
      "Total_30S30N": {
        "annual": 1.4376639123073849,
        "semi-annual": 1.687698533085264
      },
      "Total_50S30S": {
        "annual": 1.4035190474483108,
        "semi-annual": 1.1126375229893537
      },
      "Total_50S50N": {
        "annual": 1.4221050736833407,
        "semi-annual": 1.6108754775087781
      }
    },
    "unforced": {
      "Land_30N50N": {
        "interannual": 1.3879961062215058,
        "seasonal-annual": 1.4543733420467004,
        "sub-seasonal": 1.2722446114532961,
        "synoptic": 0.9550314725762121
      },
      "Land_30S30N": {
        "interannual": 1.5684797034953768,
        "seasonal-annual": 1.3855140760562383,
        "sub-seasonal": 1.0320215218679676,
        "synoptic": 0.6344408069820874
      },
      "Land_50S30S": {
        "interannual": 1.2734804296657496,
        "seasonal-annual": 1.4835739537712778,
        "sub-seasonal": 1.1166071488025653,
        "synoptic": 0.6682326701057771
      },
      "Land_50S50N": {
        "interannual": 1.5292151952174622,
        "seasonal-annual": 1.4013209418868149,
        "sub-seasonal": 1.0762109149442591,
        "synoptic": 0.6996958985943602
      },
      "Ocean_30N50N": {
        "interannual": 0.7043783826080338,
        "seasonal-annual": 0.6455934192259555,
        "sub-seasonal": 0.6137724411737419,
        "synoptic": 0.6863874501625438
      },
      "Ocean_30S30N": {
        "interannual": 1.2503414156435761,
        "seasonal-annual": 1.5516779450827425,
        "sub-seasonal": 1.1798960241814676,
        "synoptic": 1.0953812575228663
      },
      "Ocean_50S30S": {
        "interannual": 0.8539632674914032,
        "seasonal-annual": 0.8423603608480983,
        "sub-seasonal": 0.7618579649944115,
        "synoptic": 0.6782173179198747
      },
      "Ocean_50S50N": {
        "interannual": 1.192306567530281,
        "seasonal-annual": 1.388569073500126,
        "sub-seasonal": 1.0754572647719467,
        "synoptic": 0.9428927883322022
      },
      "Total_30N50N": {
        "interannual": 0.890142181535627,
        "seasonal-annual": 0.8488114296330035,
        "sub-seasonal": 0.7938998372292917,
        "synoptic": 0.7644746195371889
      },
      "Total_30S30N": {
        "interannual": 1.2881197802160111,
        "seasonal-annual": 1.5249482736415594,
        "sub-seasonal": 1.1523720464576694,
        "synoptic": 0.962505068170746
      },
      "Total_50S30S": {
        "interannual": 0.8886847211435608,
        "seasonal-annual": 0.887116494612341,
        "sub-seasonal": 0.7898809941461293,
        "synoptic": 0.6773923219536805
      },
      "Total_50S50N": {
        "interannual": 1.2352951393941365,
        "seasonal-annual": 1.3906442610537741,
        "sub-seasonal": 1.0755971788907206,
        "synoptic": 0.8809660578685662
      }
    }
  }
}

Regional metrics

The precipitation variability metrics have a set of default regions. However, users can instead define a single spatial region to compute metrics over. There are two ways to do this.

  1. Use the regions_specs parameter to define a latitude/longitude box. Parameter file example:

regions_specs={"CONUS": {"domain": {"latitude": (24.7, 49.4), "longitude": (235.22, 293.08)}}}
  1. Use a shapefile to define a region. Users must provide the path to the shapefile along with the attribute/feature pair that defines the region. Parameter file example:

region_file="CONUS.shp" # Shapefile path
attr="NAME"             # An attribute in the shapefile
feature="CONUS"         # A unique feature name that can be
                        # found under the "attr" attribute

Both options can be used at the same time. In that case, the area defined by regions_specs is applied first and can be used to trim down very large, high resolution datasets. Then the metrics are computed for the area defined by the shapefile region.

Region example

First, we generate a simple shapefile for use in this demo. The shapefile contains one feature, a box that defines the CONUS region.

[11]:
from shapely import Polygon
import geopandas as gpd
import pandas as pd

# Define region box
coords = ((233.,22.),(233.,50.),(294.,50.),(294.,22))

# Add to pandas dataframe, then convert to geopandas dataframe
df = pd.DataFrame({"Region": ["CONUS"], "Coords": [Polygon(coords)]})
gdf = gpd.GeoDataFrame(df, geometry="Coords", crs="EPSG:4326")

# Create the output location
if not os.path.exists(demo_output_directory+"/shp"):
    os.mkdir(demo_output_directory+"/shp")
gdf.to_file(demo_output_directory+'/shp/CONUS.shp')

Add the information for this shapefile to the variability_across_timescales_PS_driver.py run command.

[12]:
%%bash -s "$demo_output_directory"
variability_across_timescales_PS_driver.py -p basic_precip_variability_param.py \
--region_file $1/shp/CONUS.shp \
--attr 'Region' \
--feature 'CONUS' \
--results_dir $1/precip_variability/region_ex
demo_data_tmp/CMIP5_demo_timeseries/historical/atmos/day/pr/
pr_day_GISS-E2-H_historical_r6i1p1_*.nc
[2000, 2005]
730 365
2
demo_output/precip_variability/region_ex
demo_output/precip_variability/region_ex
demo_output/precip_variability/region_ex
['demo_data_tmp/CMIP5_demo_timeseries/historical/atmos/day/pr/pr_day_GISS-E2-H_historical_r6i1p1_20000101-20051231.nc']
GISS-E2-H.r6i1p1
['demo_data_tmp/CMIP5_demo_timeseries/historical/atmos/day/pr/pr_day_GISS-E2-H_historical_r6i1p1_20000101-20051231.nc']
GISS-E2-H.r6i1p1 365_day
2000 2005
Complete regridding from (2190, 90, 144) to (2190, 90, 180)
Cropping from shapefile
Reading region from file.
/Users/lee1043/mambaforge/envs/pmp_devel_20241106_xcdat0.7.3/lib/python3.10/site-packages/pcmdi_metrics/precip_variability/lib/lib_variability_across_timescales.py:313: RuntimeWarning: Mean of empty slice
  clim = np.nanmean(dseg, axis=0)
/Users/lee1043/mambaforge/envs/pmp_devel_20241106_xcdat0.7.3/lib/python3.10/site-packages/pcmdi_metrics/precip_variability/lib/lib_variability_across_timescales.py:341: FutureWarning: 'H' is deprecated and will be removed in a future version, please use 'h' instead.
  climtime = pd.period_range(
Complete calculating climatology and anomaly for calendar of 365_day
Complete power spectra (segment:  730  nps: 5.0 )
Complete domain and frequency average of spectral power
Complete power spectra (segment:  730  nps: 5.0 )
Complete domain and frequency average of spectral power
INFO::2024-11-20 16:49::pcmdi_metrics:: Results saved to a json file: /Users/lee1043/Documents/Research/git/pcmdi_metrics_20230620_pcmdi/pcmdi_metrics/doc/jupyter/Demo/demo_output/precip_variability/region_ex/PS_pr.day_regrid.180x90_area.freq.mean_GISS-E2-H.r6i1p1.json
2024-11-20 16:49:43,727 [INFO]: base.py(write:422) >> Results saved to a json file: /Users/lee1043/Documents/Research/git/pcmdi_metrics_20230620_pcmdi/pcmdi_metrics/doc/jupyter/Demo/demo_output/precip_variability/region_ex/PS_pr.day_regrid.180x90_area.freq.mean_GISS-E2-H.r6i1p1.json
2024-11-20 16:49:43,727 [INFO]: base.py(write:422) >> Results saved to a json file: /Users/lee1043/Documents/Research/git/pcmdi_metrics_20230620_pcmdi/pcmdi_metrics/doc/jupyter/Demo/demo_output/precip_variability/region_ex/PS_pr.day_regrid.180x90_area.freq.mean_GISS-E2-H.r6i1p1.json

The metrics output will look different than the default example. Metrics will only be produced for a single region that we defined in this shapefile.

[13]:
output_path = os.path.join(demo_output_directory,"precip_variability/region_ex/PS_pr.day_regrid.180x90_area.freq.mean_GISS-E2-H.r6i1p1.json")
with open(output_path) as f:
    metric = json.load(f)["RESULTS"]
print(json.dumps(metric, indent=2))
{
  "GISS-E2-H.r6i1p1": {
    "forced": {
      "CONUS": {
        "annual": 1.201187057408025,
        "semi-annual": 0.3809758262071558
      }
    },
    "unforced": {
      "CONUS": {
        "interannual": 0.15219095217372633,
        "seasonal-annual": 0.2042841051487,
        "sub-seasonal": 0.20652699240276556,
        "synoptic": 0.10360220715481483
      }
    }
  }
}