From 585a9038da614d272ec0c242aa412fe3abca8e10 Mon Sep 17 00:00:00 2001 From: Christina Kalb Date: Tue, 16 May 2023 12:31:37 -0600 Subject: [PATCH 1/6] Updated files --- .../cross_spectra_plot.py | 36 +++++++++++-------- .../spectra_plot.yaml | 3 ++ 2 files changed, 24 insertions(+), 15 deletions(-) diff --git a/parm/use_cases/model_applications/s2s/UserScript_obsPrecip_obsOnly_CrossSpectraPlot/cross_spectra_plot.py b/parm/use_cases/model_applications/s2s/UserScript_obsPrecip_obsOnly_CrossSpectraPlot/cross_spectra_plot.py index 12ad482c18..a846fde6c0 100755 --- a/parm/use_cases/model_applications/s2s/UserScript_obsPrecip_obsOnly_CrossSpectraPlot/cross_spectra_plot.py +++ b/parm/use_cases/model_applications/s2s/UserScript_obsPrecip_obsOnly_CrossSpectraPlot/cross_spectra_plot.py @@ -27,6 +27,9 @@ #pathdata = config_dict['pathdata'][0] plotpath = config_dict['plotpath'][0] print("Output path ",plotpath) +model = config_dict['model'] +var2 = config_dict['var2'] +var3 = config_dict['var3'] # plot layout parameters flim = 0.5 # maximum frequency in cpd for plotting @@ -36,17 +39,18 @@ contourspace = 0.1 # contour spacing N = [1, 2] # wave modes for plotting source = "" -spd = 2 +spd = 4 symmetry = "symm" #("symm", "asymm", "latband") -filenames = os.environ.get("INPUT_FILE_NAMES","ERAI_TRMM_P_symn,ERAI_P_D850_symn,ERAI_P_D200_symn").split(",") -#filenames = ['ERAI_TRMM_P_symm_'+str(spd)+'spd', -# 'ERAI_P_D850_symm_'+str(spd)+'spd', -# 'ERAI_P_D200_symm_'+str(spd)+'spd'] -vars1 = ['ERAI P', 'ERAI P', 'ERAI P'] -vars2 = ['TRMM', 'ERAI D850', 'ERAI D200'] +#filenames = os.environ.get("INPUT_FILE_NAMES","ERAI_TRMM_P_symn,ERAI_P_D850_symn,ERAI_P_D200_symn").split(",") +#vars1 = ['ERAI P', 'ERAI P', 'ERAI P'] +#vars2 = ['TRMM', 'ERAI D850', 'ERAI D200'] +filenames = os.environ.get("INPUT_FILE_NAMES","ERAI_P_D850_symn,ERAI_P_D200_symn,ERAI_P_D200_symn").split(",") +vars1 = [model+' P',model+' P',model+' P'] +vars2 = [model+' '+var2,model+' '+var3,model+' '+var3] nplot = len(vars1) +npanel =3 for pp in np.arange(0, nplot, 1): # read data from file @@ -58,8 +62,8 @@ wnum = fin['wnum'] freq = fin['freq'] - ifreq = np.where((freq[:] >= 0) & (freq[:] <= flim)) - iwave = np.where(abs(wnum[:]) <= nWavePlt) + #ifreq = np.where((freq[:] >= 0) & (freq[:] <= flim)) + #iwave = np.where(abs(wnum[:]) <= nWavePlt) STC[:, freq[:] == 0, :] = 0. STC = STC.sel(wnum=slice(-nWavePlt, nWavePlt)) @@ -75,11 +79,13 @@ pow2.where(pow2 <= 0, drop=True) if pp == 0: - Coh2 = np.empty([nplot, len(freq[ifreq]), len(wnum[iwave])]) - Phs1 = np.empty([nplot, len(freq[ifreq]), len(wnum[iwave])]) - Phs2 = np.empty([nplot, len(freq[ifreq]), len(wnum[iwave])]) - Pow1 = np.empty([nplot, len(freq[ifreq]), len(wnum[iwave])]) - Pow2 = np.empty([nplot, len(freq[ifreq]), len(wnum[iwave])]) + ifreq = np.where((freq[:] >= 0) & (freq[:] <= flim)) + iwave = np.where(abs(wnum[:]) <= nWavePlt) + Coh2 = np.full([npanel, len(freq[ifreq]), len(wnum[iwave])], np.nan) + Phs1 = np.full([npanel, len(freq[ifreq]), len(wnum[iwave])], np.nan) + Phs2 = np.full([npanel, len(freq[ifreq]), len(wnum[iwave])], np.nan) + Pow1 = np.full([npanel, len(freq[ifreq]), len(wnum[iwave])], np.nan) + Pow2 = np.full([npanel, len(freq[ifreq]), len(wnum[iwave])], np.nan) k = wnum[iwave] w = freq[ifreq] @@ -103,7 +109,7 @@ # plot coherence stp.plot_coherence(Coh2, Phs1, Phs2, symmetry, source, vars1, vars2, plotpath, flim, 20, contourmin, contourmax, - contourspace, nplot, N) + contourspace, npanel, N) # check if output file exists since plotting function # doesn't return an error code on failure diff --git a/parm/use_cases/model_applications/s2s/UserScript_obsPrecip_obsOnly_CrossSpectraPlot/spectra_plot.yaml b/parm/use_cases/model_applications/s2s/UserScript_obsPrecip_obsOnly_CrossSpectraPlot/spectra_plot.yaml index b1c58e1b59..9cad9803af 100644 --- a/parm/use_cases/model_applications/s2s/UserScript_obsPrecip_obsOnly_CrossSpectraPlot/spectra_plot.yaml +++ b/parm/use_cases/model_applications/s2s/UserScript_obsPrecip_obsOnly_CrossSpectraPlot/spectra_plot.yaml @@ -1,2 +1,5 @@ plotpath: - !ENV '${OUTPUT_DIR}' +model: 'ufs_p7' +var2: 'u850' +var3: 'u200' From 88495e53a4a846ae2f96e68816a744e283306c05 Mon Sep 17 00:00:00 2001 From: Christina Kalb Date: Thu, 8 Jun 2023 15:56:17 -0600 Subject: [PATCH 2/6] Added new cross spectra --- ...erScript_fcstS2S_obsERAI_CrossSpectra.png} | Bin ...serScript_fcstS2S_obsERAI_CrossSpectra.py} | 41 +++++++------ ...erScript_fcstS2S_obsERAI_CrossSpectra.conf | 48 +++++++++++++++ .../cross_spectra_plot.py | 6 +- .../spectra_comp.yaml | 12 ++++ .../spectra_plot.yaml | 2 +- ...pt_obsPrecip_obsOnly_CrossSpectraPlot.conf | 55 ------------------ 7 files changed, 84 insertions(+), 80 deletions(-) rename docs/_static/{UserScript_obsPrecip_obsOnly_CrossSpectraPlot.png => s2s-UserScript_fcstS2S_obsERAI_CrossSpectra.png} (100%) rename docs/use_cases/model_applications/s2s/{UserScript_obsPrecip_obsOnly_CrossSpectraPlot.py => UserScript_fcstS2S_obsERAI_CrossSpectra.py} (76%) create mode 100644 parm/use_cases/model_applications/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra.conf rename parm/use_cases/model_applications/s2s/{UserScript_obsPrecip_obsOnly_CrossSpectraPlot => UserScript_fcstS2S_obsERAI_CrossSpectra}/cross_spectra_plot.py (93%) create mode 100644 parm/use_cases/model_applications/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra/spectra_comp.yaml rename parm/use_cases/model_applications/s2s/{UserScript_obsPrecip_obsOnly_CrossSpectraPlot => UserScript_fcstS2S_obsERAI_CrossSpectra}/spectra_plot.yaml (59%) delete mode 100644 parm/use_cases/model_applications/s2s/UserScript_obsPrecip_obsOnly_CrossSpectraPlot.conf diff --git a/docs/_static/UserScript_obsPrecip_obsOnly_CrossSpectraPlot.png b/docs/_static/s2s-UserScript_fcstS2S_obsERAI_CrossSpectra.png similarity index 100% rename from docs/_static/UserScript_obsPrecip_obsOnly_CrossSpectraPlot.png rename to docs/_static/s2s-UserScript_fcstS2S_obsERAI_CrossSpectra.png diff --git a/docs/use_cases/model_applications/s2s/UserScript_obsPrecip_obsOnly_CrossSpectraPlot.py b/docs/use_cases/model_applications/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra.py similarity index 76% rename from docs/use_cases/model_applications/s2s/UserScript_obsPrecip_obsOnly_CrossSpectraPlot.py rename to docs/use_cases/model_applications/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra.py index 215ce24346..3691bb66f2 100644 --- a/docs/use_cases/model_applications/s2s/UserScript_obsPrecip_obsOnly_CrossSpectraPlot.py +++ b/docs/use_cases/model_applications/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra.py @@ -1,10 +1,10 @@ """ -UserScript: Make a Cross Spectra plot +UserScript: Compue Cross Spectra and make a plot ======================================================================== model_applications/ s2s/ -UserScript_obsPrecip_obsOnly_CrossSpectraPlot.py +UserScript_fcstS2S_obsERAI_CrossSpectra.py """ @@ -12,13 +12,12 @@ # Scientific Objective # -------------------- # -# This use case calls the METplotpy space time plot to create a sample cross -# spectra diagram -# using sample data created by METcalcpy cross spectra functions +# This use case calls the METcalcpy cross spectra function and then the METplotpy +# space time plot to compute cross-spectra and create a sample cross spectra +# diagram using sample data. # # The space time plot and cross spectra calculations were created by Maria Gehne -# at the -# Physical Sciences Labratory in NOAA +# at the Physical Sciences Labratory in NOAA. ################################################################################# # Datasets @@ -29,18 +28,18 @@ # METplus Components # ------------------ # -# This use case runs the UserScript wrapper tool to run a user provided script, -# in this case, cross_spectra_plot.py. +# This use case runs the UserScript wrapper tool to run a user provided script, +# in this case, cross_spectra.py and cross_spectra_plot.py. # ############################################################################## # METplus Workflow # ---------------- # -# This use case does not loop but plots the entire time period of data -# -# UserScript -# +# This use case computes spectra and plots for the entire time period of data. +# The use case loops over two processes, computing and plotting the +# cross-spectra. The user is able to edit the process list to turn off the +# computation part if only plotting is desired, or vice versa. # ############################################################################## @@ -49,10 +48,10 @@ # # METplus first loads all of the configuration files found in parm/metplus_config, # then it loads any configuration files passed to METplus via the command line -# with the -c option, i.e. -c parm/use_cases/model_applications/s2s/UserScript_obsPrecip_obsOnly_CrossSpectraPlot.conf +# with the -c option, i.e. -c parm/use_cases/model_applications/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra.conf # # .. highlight:: bash -# .. literalinclude:: ../../../../parm/use_cases/model_applications/s2s/UserScript_obsPrecip_obsOnly_CrossSpectraPlot.conf +# .. literalinclude:: ../../../../parm/use_cases/model_applications/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra.conf # ############################################################################# @@ -76,7 +75,7 @@ # This use case uses a Python script to perform plotting # # .. highlight:: python -# .. literalinclude:: ../../../../parm/use_cases/model_applications/s2s/UserScript_obsPrecip_obsOnly_CrossSpectraPlot/cross_spectra_plot.py +# .. literalinclude:: ../../../../parm/use_cases/model_applications/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra/cross_spectra_plot.py # ############################################################################## @@ -85,14 +84,14 @@ # # This use case can be run two ways: # -# 1) Passing in UserScript_obsPrecip_obsOnly_CrossSpectraPlot.conf, +# 1) Passing in UserScript_fcstS2S_obsERAI_CrossSpectra.conf, # then a user-specific system configuration file:: # -# run_metplus.py -c /path/to/METplus/parm/use_cases/model_applications/s2s/UserScript_obsPrecip_obsOnly_CrossSpectraPlot.conf -c /path/to/user_system.conf +# run_metplus.py -c /path/to/METplus/parm/use_cases/model_applications/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra.conf -c /path/to/user_system.conf # -# 2) Modifying the configurations in parm/metplus_config, then passing in UserScript_obsPrecip_obsOnly_CrossSpectraPlot.conf:: +# 2) Modifying the configurations in parm/metplus_config, then passing in UserScript_fcstS2S_obsERAI_CrossSpectra.conf:: # -# run_metplus.py -c /path/to/METplus/parm/use_cases/model_applications/s2s/UserScript_obsPrecip_obsOnly_CrossSpectraPlot.conf +# run_metplus.py -c /path/to/METplus/parm/use_cases/model_applications/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra.conf # # The former method is recommended. Whether you add them to a user-specific configuration file or modify the metplus_config files, the following variables must be set correctly: # @@ -143,4 +142,4 @@ # # # -# sphinx_gallery_thumbnail_path = '_static/UserScript_obsPrecip_obsOnly_CrossSpectraPlot.png' +# sphinx_gallery_thumbnail_path = '_static/s2s-UserScript_fcstS2S_obsERAI_CrossSpectra.png' diff --git a/parm/use_cases/model_applications/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra.conf b/parm/use_cases/model_applications/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra.conf new file mode 100644 index 0000000000..9013289c54 --- /dev/null +++ b/parm/use_cases/model_applications/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra.conf @@ -0,0 +1,48 @@ +[config] + +#PROCESS_LIST = UserScript(comp_spectra), UserScript(plot_spectra) +PROCESS_LIST = UserScript(plot_spectra) + +# Note: time looping is not used in this use case +LOOP_BY = REALTIME +VALID_TIME_FMT = %Y +VALID_BEG = 2014 + +USER_SCRIPT_RUNTIME_FREQ = RUN_ONCE + +[user_env_vars] +# Make output base avabilable to the script +COMP_SPECTRA_SCRIPT_OUTPUT_DIR = {OUTPUT_BASE}/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra/output + +# YAML configuration file for the cross spectra calculation +COMP_SPECTRA_YAML_CONFIG_NAME = {METPLUS_BASE}/parm/use_cases/model_applications/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra/spectra_comp.yaml + +# Input files for the cross spectra calculation +COMP_SPECTRA_INPUT_FILE_NAMES = {INPUT_BASE}/model_applications/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra/data/precip.erai.sfc.1p0.2x.2014-2016.nc,{INPUT_BASE}/model_applications/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra/data/prate_avg_ufs_p7_2014040100.nc,{INPUT_BASE}/model_applications/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra/data/u850_ufs_p7_2014040100.nc,{INPUT_BASE}/model_applications/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra/data/u200_ufs_p7_2014040100.nc + +PLOT_SPECTRA_INPUT_FILE_NAMES = {OUTPUT_BASE}/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra/output/SpaceTimeSpectra_ufs_p7_P_D850_symm_4spd.nc,{OUTPUT_BASE}/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra/output/SpaceTimeSpectra_ufs_p7_P_D200_symm_4spd.nc,{OUTPUT_BASE}/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra/output/SpaceTimeSpectra_ufs_p7_P_D200_symm_4spd.nc + +PLOT_SPECTRA_YAML_CONFIG_NAME = {METPLUS_BASE}/parm/use_cases/model_applications/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra/spectra_plot.yaml + +PLOT_SPECTRA_OUTPUT_DIR = {OUTPUT_BASE}/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra/plots/ + + +[comp_spectra] +# Settings for computing the cross-spectra +USER_SCRIPT_COMMAND = python {METCALCPY_BASE}/metcalcpy/contributed/spacetime/cross_spectra.py + +LOG_FILE = "cross_spectra.log" +LOG_LEVEL = "DEBUG" + +METCALCPY_BASE = {METPLUS_BASE}/../METcalcpy + + +[plot_spectra] +# settings for plotting the cross-spectra + +USER_SCRIPT_COMMAND = python {METPLUS_BASE}/parm/use_cases/model_applications/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra/cross_spectra_plot.py + +LOG_FILE = "cross_spectra_plot.log" +LOG_LEVEL = "INFO" + +#METPLOTPY_BASE = {METPLUS_BASE}/METplotpy diff --git a/parm/use_cases/model_applications/s2s/UserScript_obsPrecip_obsOnly_CrossSpectraPlot/cross_spectra_plot.py b/parm/use_cases/model_applications/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra/cross_spectra_plot.py similarity index 93% rename from parm/use_cases/model_applications/s2s/UserScript_obsPrecip_obsOnly_CrossSpectraPlot/cross_spectra_plot.py rename to parm/use_cases/model_applications/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra/cross_spectra_plot.py index a846fde6c0..a6bb63721e 100755 --- a/parm/use_cases/model_applications/s2s/UserScript_obsPrecip_obsOnly_CrossSpectraPlot/cross_spectra_plot.py +++ b/parm/use_cases/model_applications/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra/cross_spectra_plot.py @@ -18,7 +18,7 @@ # user can use their own, if none specified at the command line, # use the "default" example YAML config file, spectra_plot_coh2.py # Using a custom YAML reader so we can use environment variables -plot_config_file = os.getenv("YAML_CONFIG_NAME","spectra_plot.yaml") +plot_config_file = os.getenv("PLOT_SPECTRA_YAML_CONFIG_NAME","spectra_plot.yaml") config_dict = readconfig.parse_config(plot_config_file) @@ -45,7 +45,7 @@ #filenames = os.environ.get("INPUT_FILE_NAMES","ERAI_TRMM_P_symn,ERAI_P_D850_symn,ERAI_P_D200_symn").split(",") #vars1 = ['ERAI P', 'ERAI P', 'ERAI P'] #vars2 = ['TRMM', 'ERAI D850', 'ERAI D200'] -filenames = os.environ.get("INPUT_FILE_NAMES","ERAI_P_D850_symn,ERAI_P_D200_symn,ERAI_P_D200_symn").split(",") +filenames = os.environ.get("PLOT_SPECTRA_INPUT_FILE_NAMES","ERAI_P_D850_symn,ERAI_P_D200_symn,ERAI_P_D200_symn").split(",") vars1 = [model+' P',model+' P',model+' P'] vars2 = [model+' '+var2,model+' '+var3,model+' '+var3] nplot = len(vars1) @@ -114,7 +114,7 @@ # check if output file exists since plotting function # doesn't return an error code on failure expected_file = os.path.join(plotpath, - 'SpaceTimeCoherence_.png') + 'SpaceTimeCoherence.png') if not os.path.exists(expected_file): print(f"ERROR: Could not create output file: {expected_file}") sys.exit(1) diff --git a/parm/use_cases/model_applications/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra/spectra_comp.yaml b/parm/use_cases/model_applications/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra/spectra_comp.yaml new file mode 100644 index 0000000000..03703a40a8 --- /dev/null +++ b/parm/use_cases/model_applications/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra/spectra_comp.yaml @@ -0,0 +1,12 @@ +pathout: +- !ENV '${COMP_SPECTRA_SCRIPT_OUTPUT_DIR}' + +model: 'ufs_p7' +spd : 4 +nperseg : 15 # in days +segOverLap : -5 # in days +Symmetry : 'symm' +latMin : -15. +latMax : 15. +datestrt : '2014-04-01T06:00:00' # start date, format: yyyy-mm-ddTHH:MM:ss +datelast : '2014-05-04T18:00:00' # end date, format: yyyy-mm-ddTHH:MM:ss diff --git a/parm/use_cases/model_applications/s2s/UserScript_obsPrecip_obsOnly_CrossSpectraPlot/spectra_plot.yaml b/parm/use_cases/model_applications/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra/spectra_plot.yaml similarity index 59% rename from parm/use_cases/model_applications/s2s/UserScript_obsPrecip_obsOnly_CrossSpectraPlot/spectra_plot.yaml rename to parm/use_cases/model_applications/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra/spectra_plot.yaml index 9cad9803af..3386d678a1 100644 --- a/parm/use_cases/model_applications/s2s/UserScript_obsPrecip_obsOnly_CrossSpectraPlot/spectra_plot.yaml +++ b/parm/use_cases/model_applications/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra/spectra_plot.yaml @@ -1,5 +1,5 @@ plotpath: -- !ENV '${OUTPUT_DIR}' +- !ENV '${PLOT_SPECTRA_OUTPUT_DIR}' model: 'ufs_p7' var2: 'u850' var3: 'u200' diff --git a/parm/use_cases/model_applications/s2s/UserScript_obsPrecip_obsOnly_CrossSpectraPlot.conf b/parm/use_cases/model_applications/s2s/UserScript_obsPrecip_obsOnly_CrossSpectraPlot.conf deleted file mode 100644 index 768f48fa67..0000000000 --- a/parm/use_cases/model_applications/s2s/UserScript_obsPrecip_obsOnly_CrossSpectraPlot.conf +++ /dev/null @@ -1,55 +0,0 @@ -[config] - -# Documentation for this use case can be found at -# https://metplus.readthedocs.io/en/latest/generated/model_applications/s2s/UserScript_obsPrecip_obsOnly_CrossSpectraPlot.html - -# For additional information, please see the METplus Users Guide. -# https://metplus.readthedocs.io/en/latest/Users_Guide - -### -# Processes to run -# https://metplus.readthedocs.io/en/latest/Users_Guide/systemconfiguration.html#process-list -### - -PROCESS_LIST = UserScript - - -### -# Time Info -# LOOP_BY options are INIT, VALID, RETRO, and REALTIME -# If set to INIT or RETRO: -# INIT_TIME_FMT, INIT_BEG, INIT_END, and INIT_INCREMENT must also be set -# If set to VALID or REALTIME: -# VALID_TIME_FMT, VALID_BEG, VALID_END, and VALID_INCREMENT must also be set -# LEAD_SEQ is the list of forecast leads to process -# https://metplus.readthedocs.io/en/latest/Users_Guide/systemconfiguration.html#timing-control -### - -# Note: time looping is not used in this use case -LOOP_BY = REALTIME -VALID_TIME_FMT = %Y -VALID_BEG = 2020 - -USER_SCRIPT_RUNTIME_FREQ = RUN_ONCE - - -### -# UserScript Settings -# https://metplus.readthedocs.io/en/latest/Users_Guide/wrappers.html#userscript -### - -USER_SCRIPT_COMMAND = {PARM_BASE}/use_cases/model_applications/s2s/UserScript_obsPrecip_obsOnly_CrossSpectraPlot/cross_spectra_plot.py - -[user_env_vars] - -# Difficulty index specific variables - -LOG_FILE = "cross_spectra_plot.log" - -LOG_LEVEL = "INFO" - -INPUT_FILE_NAMES = {INPUT_BASE}/model_applications/s2s/UserScript_obsPrecip_obsOnly_CrossSpectraPlot/SpaceTimeSpectra_ERAI_P_D200_symm_2spd.nc,{INPUT_BASE}/model_applications/s2s/UserScript_obsPrecip_obsOnly_CrossSpectraPlot/SpaceTimeSpectra_ERAI_TRMM_P_symm_2spd.nc,{INPUT_BASE}/model_applications/s2s/UserScript_obsPrecip_obsOnly_CrossSpectraPlot/SpaceTimeSpectra_ERAI_P_D850_symm_2spd.nc - -YAML_CONFIG_NAME = {METPLUS_BASE}/parm/use_cases/model_applications/s2s/UserScript_obsPrecip_obsOnly_CrossSpectraPlot/spectra_plot.yaml - -OUTPUT_DIR = {OUTPUT_BASE}/plots From 4cbfed81bad7966d78b5092e463e16ba113d1a79 Mon Sep 17 00:00:00 2001 From: Christina Kalb Date: Thu, 8 Jun 2023 16:06:20 -0600 Subject: [PATCH 3/6] Added use case tests --- .github/parm/use_case_groups.json | 2 +- internal/tests/use_cases/all_use_cases.txt | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/parm/use_case_groups.json b/.github/parm/use_case_groups.json index 0567a7db3e..646816f7a9 100644 --- a/.github/parm/use_case_groups.json +++ b/.github/parm/use_case_groups.json @@ -177,7 +177,7 @@ { "category": "s2s", "index_list": "4", - "run": false + "run": true }, { "category": "s2s", diff --git a/internal/tests/use_cases/all_use_cases.txt b/internal/tests/use_cases/all_use_cases.txt index fbd7fa0131..57a16c3f41 100644 --- a/internal/tests/use_cases/all_use_cases.txt +++ b/internal/tests/use_cases/all_use_cases.txt @@ -119,7 +119,7 @@ Category: s2s 1::TCGen_fcstGFSO_obsBDECKS_GDF_TDF:: model_applications/s2s/TCGen_fcstGFSO_obsBDECKS_GDF_TDF.conf:: metplotpy_env,cartopy,metplus 2::UserScript_obsPrecip_obsOnly_Hovmoeller:: model_applications/s2s/UserScript_obsPrecip_obsOnly_Hovmoeller.conf:: metplotpy_env,cartopy 3:: UserScript_obsPrecip_obsOnly_CrossSpectraPlot:: model_applications/s2s/UserScript_obsPrecip_obsOnly_CrossSpectraPlot.conf:: spacetime_env -4:: UserScript_obsERA_obsOnly_Stratosphere:: model_applications/s2s/UserScript_obsERA_obsOnly_Stratosphere.conf:: metplotpy_env,metdataio +4:: UserScript_obsPrecip_obsOnly_CrossSpectraPlot:: model_applications/s2s/UserScript_obsPrecip_obsOnly_CrossSpectraPlot.conf:: metplotpy_env,metdataio 5::SeriesAnalysis_fcstCFSv2_obsGHCNCAMS_climoStandardized_MultiStatisticTool:: model_applications/s2s/SeriesAnalysis_fcstCFSv2_obsGHCNCAMS_climoStandardized_MultiStatisticTool.conf:: netcdf4_env 6::GridStat_fcstCFSv2_obsGHCNCAMS_MultiTercile:: model_applications/s2s/GridStat_fcstCFSv2_obsGHCNCAMS_MultiTercile.conf:: netcdf4_env From 16c0fb6587251fab2c371cf07e8c4a5761b71d2b Mon Sep 17 00:00:00 2001 From: Christina Kalb Date: Fri, 9 Jun 2023 11:10:35 -0600 Subject: [PATCH 4/6] Cross Spectra testing --- .github/parm/use_case_groups.json | 4 ++-- internal/tests/use_cases/all_use_cases.txt | 4 ++-- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/.github/parm/use_case_groups.json b/.github/parm/use_case_groups.json index 646816f7a9..d38e88b794 100644 --- a/.github/parm/use_case_groups.json +++ b/.github/parm/use_case_groups.json @@ -172,12 +172,12 @@ { "category": "s2s", "index_list": "3", - "run": false + "run": true }, { "category": "s2s", "index_list": "4", - "run": true + "run": false }, { "category": "s2s", diff --git a/internal/tests/use_cases/all_use_cases.txt b/internal/tests/use_cases/all_use_cases.txt index 57a16c3f41..909917f2bc 100644 --- a/internal/tests/use_cases/all_use_cases.txt +++ b/internal/tests/use_cases/all_use_cases.txt @@ -118,8 +118,8 @@ Category: s2s 0::GridStat_SeriesAnalysis_fcstNMME_obsCPC_seasonal_forecast:: model_applications/s2s/GridStat_SeriesAnalysis_fcstNMME_obsCPC_seasonal_forecast.conf:: netcdf4_env 1::TCGen_fcstGFSO_obsBDECKS_GDF_TDF:: model_applications/s2s/TCGen_fcstGFSO_obsBDECKS_GDF_TDF.conf:: metplotpy_env,cartopy,metplus 2::UserScript_obsPrecip_obsOnly_Hovmoeller:: model_applications/s2s/UserScript_obsPrecip_obsOnly_Hovmoeller.conf:: metplotpy_env,cartopy -3:: UserScript_obsPrecip_obsOnly_CrossSpectraPlot:: model_applications/s2s/UserScript_obsPrecip_obsOnly_CrossSpectraPlot.conf:: spacetime_env -4:: UserScript_obsPrecip_obsOnly_CrossSpectraPlot:: model_applications/s2s/UserScript_obsPrecip_obsOnly_CrossSpectraPlot.conf:: metplotpy_env,metdataio +3:: UserScript_fcstS2S_obsERAI_CrossSpectra:: model_applications/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra.conf:: spacetime_env +4:: UserScript_obsERA_obsOnly_Stratosphere:: model_applications/s2s/UserScript_obsERA_obsOnly_Stratosphere.conf:: metplotpy_env,metdataio 5::SeriesAnalysis_fcstCFSv2_obsGHCNCAMS_climoStandardized_MultiStatisticTool:: model_applications/s2s/SeriesAnalysis_fcstCFSv2_obsGHCNCAMS_climoStandardized_MultiStatisticTool.conf:: netcdf4_env 6::GridStat_fcstCFSv2_obsGHCNCAMS_MultiTercile:: model_applications/s2s/GridStat_fcstCFSv2_obsGHCNCAMS_MultiTercile.conf:: netcdf4_env From d21c3bac7350f8e84ea99199f3a8337b002bbd5f Mon Sep 17 00:00:00 2001 From: Christina Kalb Date: Fri, 9 Jun 2023 12:27:00 -0600 Subject: [PATCH 5/6] Updates to Cross Spectra --- .../s2s/UserScript_fcstS2S_obsERAI_CrossSpectra.conf | 5 +---- 1 file changed, 1 insertion(+), 4 deletions(-) diff --git a/parm/use_cases/model_applications/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra.conf b/parm/use_cases/model_applications/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra.conf index 9013289c54..9584907959 100644 --- a/parm/use_cases/model_applications/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra.conf +++ b/parm/use_cases/model_applications/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra.conf @@ -1,7 +1,6 @@ [config] -#PROCESS_LIST = UserScript(comp_spectra), UserScript(plot_spectra) -PROCESS_LIST = UserScript(plot_spectra) +PROCESS_LIST = UserScript(comp_spectra), UserScript(plot_spectra) # Note: time looping is not used in this use case LOOP_BY = REALTIME @@ -44,5 +43,3 @@ USER_SCRIPT_COMMAND = python {METPLUS_BASE}/parm/use_cases/model_applications/s2 LOG_FILE = "cross_spectra_plot.log" LOG_LEVEL = "INFO" - -#METPLOTPY_BASE = {METPLUS_BASE}/METplotpy From f1b432b61b6dbaf2052c12b3b81cada112001280 Mon Sep 17 00:00:00 2001 From: Christina Kalb Date: Fri, 9 Jun 2023 13:49:01 -0600 Subject: [PATCH 6/6] Updates to cross spectra --- .../s2s/UserScript_fcstS2S_obsERAI_CrossSpectra.py | 3 +++ .../cross_spectra_plot.py | 2 +- 2 files changed, 4 insertions(+), 1 deletion(-) diff --git a/docs/use_cases/model_applications/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra.py b/docs/use_cases/model_applications/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra.py index 3691bb66f2..14991f557c 100644 --- a/docs/use_cases/model_applications/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra.py +++ b/docs/use_cases/model_applications/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra.py @@ -23,6 +23,9 @@ # Datasets # -------- # +# * Forecast dataset: UFS Prototype 7 +# * Observation dataset: ERAI +# ############################################################################## # METplus Components diff --git a/parm/use_cases/model_applications/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra/cross_spectra_plot.py b/parm/use_cases/model_applications/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra/cross_spectra_plot.py index a6bb63721e..994ffd11a4 100755 --- a/parm/use_cases/model_applications/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra/cross_spectra_plot.py +++ b/parm/use_cases/model_applications/s2s/UserScript_fcstS2S_obsERAI_CrossSpectra/cross_spectra_plot.py @@ -114,7 +114,7 @@ # check if output file exists since plotting function # doesn't return an error code on failure expected_file = os.path.join(plotpath, - 'SpaceTimeCoherence.png') + 'SpaceTimeCoherence_.png') if not os.path.exists(expected_file): print(f"ERROR: Could not create output file: {expected_file}") sys.exit(1)