From d99bc3dc5c36a2e0182445f442e7c19490669b05 Mon Sep 17 00:00:00 2001 From: John Halley Gotway Date: Tue, 12 Nov 2024 16:07:34 -0700 Subject: [PATCH] Feature #2729 tc_diag (#3011) * Per #2729, get rid of extra blank line in log message about manually deleting temp files. * Per #2729, fix log message describing the range/azimuth grid. * Per #2729, Update TC-Diag Python driver code to convert rotation angles from degree clockwise from due East to radians counter-clockwise from due East. * Per #2729, complete the TC-Diag documentation. * Per #2729, more tweaks * Per #2729, clarify that some diagnostics are directly extracted from the ATCF track file rather than being computed from the cylindrical coordinates grid. * Update docs/Users_Guide/tc-diag.rst Co-authored-by: KathrynNewman * Update docs/Users_Guide/tc-diag.rst Co-authored-by: KathrynNewman * Update docs/Users_Guide/tc-diag.rst Co-authored-by: KathrynNewman * Update docs/Users_Guide/tc-diag.rst Co-authored-by: KathrynNewman * Update docs/Users_Guide/tc-diag.rst Co-authored-by: KathrynNewman --------- Co-authored-by: KathrynNewman --- docs/Users_Guide/tc-diag.rst | 95 ++++++++++++++++--- .../tc_diag_driver/post_resample_driver.py | 9 +- src/basic/vx_config/temp_file.cc | 2 +- src/tools/tc_utils/tc_diag/tc_diag.cc | 4 +- 4 files changed, 95 insertions(+), 15 deletions(-) diff --git a/docs/Users_Guide/tc-diag.rst b/docs/Users_Guide/tc-diag.rst index edcafa62dd..14c6e5ffbd 100644 --- a/docs/Users_Guide/tc-diag.rst +++ b/docs/Users_Guide/tc-diag.rst @@ -63,8 +63,6 @@ Optional Arguments for tc_diag 6. The **-v level** option indicates the desired level of verbosity. The contents of "level" will override the default setting of 2. Setting the verbosity to 0 will make the tool run with no log messages, while increasing the verbosity above 1 will increase the amount of logging. -.. note:: Setting the **MET_KEEP_TEMP_FILE** (:numref:`met_keep_temp_file`) environment variable retains the temporary NetCDF cylindrical coordinate files for development, testing, and debugging purposes. - tc_diag Configuration File -------------------------- @@ -130,7 +128,7 @@ The **domain_info** entry is an array of dictionaries. Each dictionary consists The **n_range** entry is an integer specifying the number of equally spaced range intervals in the range-azimuth grid to be used for this data source. -The **n_azimuth** entry is an integer specifying the number of equally spaced azimuth intervals in the range-azimuth grid to be used for this data source. The azimuthal grid spacing is 360 / **n_azimuth** degrees. +The **n_azimuth** entry is an integer specifying the number of equally spaced azimuth intervals in the range-azimuth grid to be used for this data source. The azimuthal grid spacing is 360 / **n_azimuth** degrees. Azimuths are defined by MET as *degrees clockwise* from due east. However, the TC-Diag Python code expects them as *radians counter-clockwise* from due east. The **tc_diag_driver/post_resample_driver.py** driver script performs the neccessary rotation and conversion operations. The **delta_range_km** entry is a floating point value specifying the spacing of the range rings in kilometers. @@ -211,7 +209,7 @@ Configuring Vortex Removal Option The **vortex_removal** flag entry is a boolean specifying whether or not vortex removal logic should be applied. -.. note:: As of MET version 11.1.0, vortex removal logic is not yet supported. +.. note:: As of MET version 12.0.0, vortex removal logic is not yet supported. Configuring Data Input and Output Options ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ @@ -249,23 +247,98 @@ The TC-Diag tool writes up to three output data types, as specified by flags in **CIRA Diagnostics Output** -When the **cira_diag_flag** configuration entry is set to true, an ASCII CIRA diagnostics output file is written for each model track provided. +When the **cira_diag_flag** configuration entry is set to true, an ASCII CIRA diagnostics output file is written for each model track provided. These files are named using the **output_base_format**, described above, followed by the **_diag.dat** suffix. + +These output files contain tabular ASCII data with diagnostic values either extracted directly from the input ATCF track file or computed from the gridded data, after converting it to a storm-centric cylindrical grid. One output file is created for each track from each model source. The output consists of the following sections: + + - Two header lines list the model name, initialization time, storm basin, and integer storm number (of the season). + + - The **STORM DATA** section contains single diagnostic values either extracted from the ATCF track file or computed from the cylindrical grid for each forecast lead time. This section begins with a line named **TIME** defining the forecast lead time of each track point in hours. The following lines contain the requested storm diagnostics. For example, **MAXWIND** contains the maximum wind speed reported in the ATCF track file and **SST** contains the average sea surface temperature computed in the range/azimuth grid. + + - The **SOUNDING DATA** section contains diagnostics computed separately for each vertical level. The vertical levels are typically the surface (e.g. **SURF**) followed by pressure levels (e.g. **0850**). This section begins with two lines named **NLEV** and **TIME** defining the number of vertical levels and their values and the forecast lead times for which diagnostics were computed, respectively. The level name is appended to each diagnostic name. For example, the **T_0850** contains the average temperature value within the range/azimuth grid at the 850 mb pressure level. + + - Each diagnostic output line contains: + + - Diagnostic name (with or without the level) e.g. **SHR_MAG** for magnitude of wind shear + + - Units string enclosed in parenthesis e.g. **(KT)** for knots -TODO: Details will be added for issue dtcenter/MET#2729. + - The diagnostic values computed for each lead time e.g. **13 10 14 ...** **NetCDF Diagnostics Output** -When the **nc_diag_flag** configuration entry is set to true, a NetCDF output file containing the computed diagnostics is written for each model track provided. +When the **nc_diag_flag** configuration entry is set to true, a NetCDF output file containing the computed diagnostics is written for each model track provided. These files contain the same data provided in the CIRA Diagnostics Output but formatted in NetCDF instead of ASCII. These files are named using the **output_base_format**, described above, followed by the **_diag.nc** suffix. + +.. _table_TC-Diag_Dimensions_NetCDF_diagnostics: + +.. list-table:: Dimensions defined in NetCDF Diagnostics output + :widths: auto + :header-rows: 2 + + * - tc_diag NETCDF DIMENSIONS + - + * - NetCDF Dimension + - Description + * - time + - Time dimension for the number of track point valid times + * - pressure + - Vertical dimension for the number of pressure levels + +.. role:: raw-html(raw) + :format: html + +.. _table_TC-Diag_Variables_NetCDF_diagnostics: -TODO: Details will be added for issue dtcenter/MET#2729. +.. list-table:: Variables defined in NetCDF Diagnostics output + :widths: auto + :header-rows: 2 + + * - tc_diag NETCDF VARIABLES + - + - + * - NetCDF Variable + - Dimension + - Description + * - storm_id + - NA + - Tropical Cyclone Storm ID (BBNNYYYY) consisting of 2-letter basin name, 2-digit storm number, and 4-digit year + * - model + - NA + - Track ATCF ID model name + * - init_time + - NA + - Track initialization time string in YYYYMMDD_HHMMSS format + * - init_time_ut + - NA + - Track initialization time string in unixtime (seconds since January 1, 1970) format + * - valid_time + - time + - Track point valid time string in YYYYMMDD_HHMMSS format + * - valid_time_ut + - time + - Track point valid time string in unixtime (seconds since January 1, 1970) format + * - lead_time + - time + - Track point forecast lead time string in HHMMSS format + * - lead_time_sec + - time + - Track point forecast lead time integer number of seconds + * - {DOMAIN}_domain + - NA + - Attributes define the range/azimuth grid for the {DOMAIN} domain: **n_range**, **n_azimuth**, **delta_range_km** + * - Diagnostic values + - time or time and pressure + - Computed diagnostic values for each track point and, optionally, pressure level. The **units** attribute defines the units of the diagnostic values. **NetCDF Range-Azimuth Output** -When the **nc_rng_azi_flag** configuration entry is set to true, a NetCDF output file containing the cylindrical coordinate range-azimuth data is written for each combination of model track provided and domain specified. For example, if three model tracks are provided and data for both *parent* and *nest* domains are provided, six of these NetCDF output files will be written. +When the **nc_rng_azi_flag** configuration entry is set to true, a NetCDF output file containing the cylindrical range-azimuth data is written for each combination of model track provided and domain specified. For example, if three model tracks are provided and data for both *parent* and *nest* domains are provided, six of these NetCDF output files will be written. + +The NetCDF range-azimuth output is named using the **output_base_format**, described above, followed by **_cyl_grid_{DOMAIN}.nc**, where **{DOMAIN}** is specified by the **domain** string in each **domain_info** array entry. -The NetCDF range-azimuth output is named using the following naming convention: +This NetCDF file contains a concatenation of the data from the temporary NetCDF files created for each track point. For each track point, TC-Diag creates a temporary NetCDF file and calls Python code to read the cylindrical grid data and compute diagnostics. By default, these temporary NetCDF files are deleted at the end of each run, but if the **nc_rng_azi_flag** is true, the data for each track point is concatenated into a single output file for each track. -**tc_diag_STORMID_TECH_YYYYMMDDHH_cyl_grid_DOMAIN.nc** where STORMID is the 2-letter basin name, 2-digit storm number, and 4-digit year, TECH is the acronym for the objective technique, YYYYMMDDHH is the track initialization time, and DOMAIN is the domain name. +.. note:: Setting the **MET_KEEP_TEMP_FILE** (:numref:`met_keep_temp_file`) environment variable retains the temporary NetCDF cylindrical grid files for development, testing, and debugging purposes. The NetCDF range-azimuth file contains the dimensions and variables shown in :numref:`table_TC-Diag_Dimensions_NetCDF_range_azimuth` and :numref:`table_TC-Diag_Variables_NetCDF_range_azimuth`. diff --git a/scripts/python/tc_diag/tc_diag_driver/post_resample_driver.py b/scripts/python/tc_diag/tc_diag_driver/post_resample_driver.py index 445470ca52..1bc1606fc5 100644 --- a/scripts/python/tc_diag/tc_diag_driver/post_resample_driver.py +++ b/scripts/python/tc_diag/tc_diag_driver/post_resample_driver.py @@ -140,7 +140,14 @@ def diag_calcs( land_lut = diag_vars.get_land_lut(land_lut_file) radii_1d = input_data[config.in_radii_name] _validate_radii(config.radii_to_validate, radii_1d, data_path) - azimuth_1d = input_data[config.in_azimuth_name] + + # MET #2729: Modify the azimuth values reported by MET + # - Subtract from 360 degrees to convert rotation angle + # from clockwise to counter-clockwise + # - Convert from degrees to radians + azimuth_1d_deg = (360 - input_data[config.in_azimuth_name]) % 360 + azimuth_1d = np.deg2rad(azimuth_1d_deg) + theta_2d, radii_2d = np.meshgrid(azimuth_1d, radii_1d) atcf_tech_id = _parse_atcf_id(input_data[config.full_track_line_name]) track = _dataset_track_lines_to_track( diff --git a/src/basic/vx_config/temp_file.cc b/src/basic/vx_config/temp_file.cc index 0a8ab6c715..5fc63f79c6 100644 --- a/src/basic/vx_config/temp_file.cc +++ b/src/basic/vx_config/temp_file.cc @@ -74,7 +74,7 @@ void remove_temp_file(const ConcatString file_name) { if (nullptr != keep_temp && (0 == strcmp(keep_temp, "true") || 0 == strcmp(keep_temp, "yes"))) { mlog << Debug(2) << "The temporary file (" - << file_name << ") was not deleted. Please remove it manually\n\n"; + << file_name << ") was not deleted. Please remove it manually.\n"; return; } diff --git a/src/tools/tc_utils/tc_diag/tc_diag.cc b/src/tools/tc_utils/tc_diag/tc_diag.cc index 1644333772..00abca8909 100644 --- a/src/tools/tc_utils/tc_diag/tc_diag.cc +++ b/src/tools/tc_utils/tc_diag/tc_diag.cc @@ -2210,8 +2210,8 @@ void TmpFileInfo::setup_nc_file(const DomainInfo &di, << "Defining cylindrical coordinates for (Lat, Lon) = (" << pnt_ptr->lat() << ", " << pnt_ptr->lon() << "), Range = " << ra_grid.range_n() << " every " << ra_grid.range_delta_km() - << ra_grid.range_n() << " every " << ra_grid.range_delta_km() - << "km, Azimuth = " << ra_grid.azimuth_n() << "\n"; + << " km, Azimuth = " << ra_grid.azimuth_n() << " every " + << ra_grid.azimuth_delta_deg() << " degrees.\n"; // Write track info write_tc_storm(tmp_out,