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

merge develop and new ifi support #47

Merged
merged 139 commits into from
Jan 19, 2023

Conversation

SamuelTrahanNOAA
Copy link

@SamuelTrahanNOAA SamuelTrahanNOAA commented Jan 18, 2023

Merges NOAA-EMC#536 into RRFS_dev

That gives us a few months of updates from develop and the latest ifi, which is still under review but should be merged soon.

Differences between this and the ifi pull request branch where --- is the ifi branch and +++ is this PR:

diff --git a/parm/fv3lam_rrfs.xml b/parm/fv3lam_rrfs.xml
index d5b68a9..fd384ad 100755
--- a/parm/fv3lam_rrfs.xml
+++ b/parm/fv3lam_rrfs.xml
@@ -1790,7 +1790,7 @@
        <param>
        <shortname>VIL_ON_ENTIRE_ATMOS</shortname>
        <pname>VIL</pname>
-       <scale>4.0</scale>
+       <scale>7.0</scale>
        </param>

        <param>
diff --git a/parm/postxconfig-NT-fv3lam_rrfs.txt b/parm/postxconfig-NT-fv3lam_rrfs.txt
index 938481e..48c9423 100644
--- a/parm/postxconfig-NT-fv3lam_rrfs.txt
+++ b/parm/postxconfig-NT-fv3lam_rrfs.txt
@@ -9742,7 +9742,7 @@ entire_atmos_single_lyr
 0
 0.0
 1
-4.0
+7.0
 0
 0
 0
diff --git a/sorc/ncep_post.fd/CLDRAD.f b/sorc/ncep_post.fd/CLDRAD.f
index 58bf95e..c506228 100644
--- a/sorc/ncep_post.fd/CLDRAD.f
+++ b/sorc/ncep_post.fd/CLDRAD.f
@@ -2098,11 +2098,18 @@ snow_check:   IF (QQS(I,J,L)>=QCLDmin) THEN
 !    However, for RAPv5/HRRRv4, paramater 711 will be supplied as
 !    the GSD cloud-base height, and parameter 798 will be the
 !    corresponding cloud-base pressure. (J. Kenyon, 4 Nov 2019)
+! -- E. James, 15 Dec 2022
+!    The above experimental diagnostic, developed for the HRRR with
+!    lots of "add-ons" to correct for the HRRR's low bias in cloud
+!    cover, needs to be revised for the RRFS with its more extensive
+!    cloudiness.  For an FAA deliverable due Feb 2023, the diagnostic
+!    is being modified to get rid of some of the add ons.

 !    Parameters 711/798: experimental ceiling diagnostic #2 (height and pressure, respectively)
         IF ((IGET(711)>0) .OR. (IGET(798)>0)) THEN
           ! set minimum cloud fraction to represent a ceiling
-          ceiling_thresh_cldfra = 0.4
+!          ceiling_thresh_cldfra = 0.4
+          ceiling_thresh_cldfra = 0.5
           ! set some constants for ceiling adjustment in snow (retained from legacy algorithm, also in calvis.f)
           rhoice = 970.
           coeffp = 10.36
@@ -2192,23 +2199,24 @@ snow_check:   IF (QQS(I,J,L)>=QCLDmin) THEN
                 end do
                 !-- end of search 2

-                zceil = min(zceil1,zceil2) ! choose lower of zceil1 and zceil2
+!                zceil = min(zceil1,zceil2) ! choose lower of zceil1 and zceil2
+                zceil = zceil1
                 !-- Search for "indefinite ceiling" (vertical visibility) conditions:  consider
                 ! lowering of apparent ceiling due to falling snow (retained from legacy
                 ! diagnostic); this is extracted from calvis.f (visibility diagnostic)
-                if (QQS(i,j,LM)>1.e-10) then
-                  TV=T(I,J,lm)*(H1+D608*Q(I,J,lm))
-                  RHOAIR=PMID(I,J,lm)/(RD*TV)
-                  vovermd = (1.+Q(i,j,LM))/rhoair + QQS(i,j,LM)/rhoice
-                  concfp = QQS(i,j,LM)/vovermd*1000.
-                  betav = coeffp*concfp**exponfp + 1.e-10
-                  vertvis = 1000.*min(90., const1/betav)
-                  if (vertvis < zceil-FIS(I,J)*GI ) then ! if vertvis is more restictive than zceil found above; set zceil to vertvis
-                    ! note that FIS is geopotential of the surface (ground), and GI is 1/g
-                    zceil = FIS(I,J)*GI + vertvis
-                  end if
-                end if
+!                if (QQS(i,j,LM)>1.e-10) then
+!                  TV=T(I,J,lm)*(H1+D608*Q(I,J,lm))
+!                  RHOAIR=PMID(I,J,lm)/(RD*TV)
+!                  vovermd = (1.+Q(i,j,LM))/rhoair + QQS(i,j,LM)/rhoice
+!                  concfp = QQS(i,j,LM)/vovermd*1000.
+!                  betav = coeffp*concfp**exponfp + 1.e-10
+!                  vertvis = 1000.*min(90., const1/betav)
+!                  if (vertvis < zceil-FIS(I,J)*GI ) then ! if vertvis is more restictive than zceil found above; set zceil to vertvis
+!                    ! note that FIS is geopotential of the surface (ground), and GI is 1/g
+!                    zceil = FIS(I,J)*GI + vertvis
+!                  end if
+!                end if

                 ceil(I,J) = zceil
             ENDDO      ! i loop
diff --git a/sorc/ncep_post.fd/INITPOST_NETCDF.f b/sorc/ncep_post.fd/INITPOST_NETCDF.f
index 046753a..474e351 100644
--- a/sorc/ncep_post.fd/INITPOST_NETCDF.f
+++ b/sorc/ncep_post.fd/INITPOST_NETCDF.f
@@ -889,7 +889,7 @@
         call read_netcdf_3d_para(ncid3d,im,jm,ista,ista_2l,iend,iend_2u,jsta,jsta_2l,jend,jend_2u, &
         spval,VarName,cfr(ista_2l,jsta_2l,1),lm)
       else
-        VarName='cldfra'
+        VarName='cldfra_bl'
         call read_netcdf_3d_para(ncid2d,im,jm,ista,ista_2l,iend,iend_2u,jsta,jsta_2l,jend,jend_2u, &
         spval,VarName,cfr(ista_2l,jsta_2l,1),lm)
       endif

SamuelTrahanNOAA and others added 30 commits October 18, 2021 19:52
* Turn on GSD cloud ceiling calculation for RRFS dev.

* Updates to UPP for RRFS applications (NOAA-GSL#3)

* Updates to UPP for RRFS applications:
1) Adding a RRFS-specific .xml control file and a corresponding .txt flat file.  Note that script changes (pending) are needed to leverage the new flat file.  However, this code will work in current real-time configurations.
2) Adding GSL experimental ceiling diagnostics, GSL visibility diagnostic, and GSL sea-level pressure reduction (MAPS).  Also adding TKE and aerosol number concentrations.
3) Code clean-up for ceiling-related diagnostics; added comments, etc.
4) Removing several non-needed variables, originally inherited from FV3-SAR community configuration.

* Updating UPP control files to specify GRIB2 generating center as "noaa_fsl_boulder" and the generating process as "hrrr".  The "hrrr" specification is temporary, and will eventually be switched to "rrfs" once required changes to the "NCEPLIBS-g2tmpl" library are available. (NOAA-GSL#4)

* Fix some out-of-bounds reads that caused the RRFS UPP to crash. (NOAA-GSL#5)

* Adding README file (NOAA-GSL#7)

* Adding README file to describe process of making a "flat" file.

* Updates to README to improve explanation of input/output files.

* Code to read in Flash Flood Guidance (FFG) and Average Recurrence Interval (ARI) precipitation datasets for comparison with model QPF within UPP.

* Fixed a syntax error in SURFCE.f

* Getting rid of GRIB1 output option to be consistent with rest of code.

* Changing field numbers to avoid conflict with existing RRFS-dev1 fields.

* Putting exceedance grids in flat files for testing in RRFS UPP.

* Corrected the 1h and run total precip names for calculating exceedances in SURFCE.f

* Bug fix in SURFCE.f if statements.

* Removing changes to RQSTFLD.F since GRIB1 is no longer used in UPP.

* Merging NOAA-GSL development on top of NOAA-EMC UPP for testing.

* Correcting minor typos in SURFCE.f to allow testing.

* Update code based on testing with RRFS cases.

* Update part of the code based on current EMC develop branch for comparing the test results with the merged version.(NOAA-GSL#9)

* Fixed several bugs in the code.

* Modifications to SURFCE.f to check for existence of FFG files.

* Bug fixes for FFG file existence check, and changes to handle rotated lat-lon grid interpolation for FFG

* Bug fixes for FFG existence checks in SURFCE.f

* Another bug fix for SURFCE.f

* Updating XML and flat txt files to include a 65th vertical level to be consistent with updated FV3LAM model with higher model top. (NOAA-GSL#13)

* Code cleanup for QPF - FFG comparison.  Comparison put into subroutine.

* Cleanup of SURFCE.f; moving the FFG comparisons into a subroutine.

* Final cleanup of exceedance code for QPF vs FFG.

* Removing some commented out variable declarations.

* Additional cleanup recommended by Ming: we really only need two exceedance variables; one for 1h FFG and one for run total FFG exceedances.

* Further cleanup of FFG code, simplifying to two fields (1h acc and run total acc)

* Adding ARI comparison fields for 2y, 5y, 10y, and 100y ARIs.

* Changes to output 9 soil levels from FV3LAM if we are running 9 level RUC LSM.

* Adding flat txt file for UPP.

* Commenting out the use of the ARI exceedances for now.  We can switch them on later.

* Bug fix in INITPOST_NETCDF.f : need to use both ncid2d and ncid3d in this subroutine!

* Adding NOAA-GSL code changes on top of latest NOAA-EMC UPP.

* Couple of bug fixes in NOAA-EMC code.  Bugs were leading to PRMSL and -10C REFD being all zeroes.

* Cleaning up code to get rid of unnecessary differences from EMC.

* Putting all new GSL variables into EMC's unified post_avblflds.xml.  Note that EMC's unified post_avblflds.xml does not validate using the avblflds Schema.

* Updating postconfig-NT.txt file for GSL RRFS based on merged post_avblflds.xml file.

* Adding RRFS control files to makefile.

* Changing back scale for WEASD_ON_SURFACE to previous default, thanks to suggestion from Wen Meng.

* Reverting name of cldfra based on feedback from Eric Aligo.

* Reverting changes in fv3lam_post_avblflds.xml since GSL new variables are now included in post_avblflds.xml

* Changing experimental ceiling level type from "ceiling" to "cloud_ceilng"

* Updating 3drtma_postcntrl.xml with revised name for GSD_EXP_CEILING.  This also affects postxconfig-NT-3drtma.txt.  postxconfig-NT-fv3lam_rrfs.txt also changed due to changes in post_avblflds.xml

* Introducing if statement for call of NGMSLP, to avoid calling unless it is needed.

Co-authored-by: Ming.Hu <Ming.Hu@noaa.gov>
Co-authored-by: Christina Holt <56881914+christinaholtNOAA@users.noreply.github.com>
Co-authored-by: Christina Holt <Christina.Holt@noaa.gov>
Co-authored-by: Jaymes Kenyon <jaymes.kenyon@noaa.gov>
Co-authored-by: Samuel Trahan (NOAA contractor) <39415369+SamuelTrahanNOAA@users.noreply.github.com>
* Doxygen for CALDRG.f

* Delete CALDWP.f

* Revert "Delete CALDWP.f"

This reverts commit 575cd93.
* Add gtg code as submodule.

* Remove manage_externals.

* Sync with the changes from GFSV16.

* Add change logs for POSTGRB2TBL default setting.
* add option to build with GTG code or stubs

* make IP optional depending on GTG option.

* GTG code depends on a file that only resides in the gtg repo

* fix a big boo-boo

* move sorc/post_gtg.fd to sorc/ncep_post.fd/post_gtg.fd and update build path to GTG

* correct the name of the submodule.  fix mixed indents

* move map_routines.F90 into the GTG src list
* Add command line arguments in compile_upp.sh for options, e.g. building with gtg code,
building with wrfio stub code, turning on cmake verbose.

* Remove legacy GNU make capability.
* Remove read interfaces INITPOST_GFS_NEMS, INITPOST_GFS_NEMS_MPIIO and INITPOST_GFS_NMM.

* Change linking order for w3nco and nemsio

* Remove INITPOST_GFS_NETCDF

* Remove INITPOST_GFS_NEMS.f, INITPOST_GFS_NETCDF.f, INITPOST_NEMS.f, INITPOST_NEMS_MPIIO.f from UPP code.

* Fix build failture.

* Clean up legacy makefile

* Clean up another two makefiles

* Add back INITPOST_GFS_NETCDF
* Add changes for WCOSS2 Acorn.

* Add changes for Dogwood.

* Add changes for WCOSS2.

* Change modulefile on wcoss2 in LUA format based on Kate's comments.

* Add machine recognition for cactus and WCOSS1 P3.5 based on Eric's comments
* modified:   scripts/exgdas_atmos_nceppost.sh

* modified:   scripts/exgfs_atmos_nceppost.sh
…C#441)

* Changes for parallel netcdf read for regional FV3 interface

* Clean up debugging code

* Replace small with the one defined in params_mod based on Huiya's comments.
…stic output. All results match standalone program.
* Doxygen for CALDRG.f

* This is part of Issue NOAA-EMC#392
Fixes the doxygen warnings in CALGUST.f

Please review this subroutine. Thank you.
* Modify CALUPDHEL.f for restricting undefined grids in computation.

* Update VERSION to 10.0.12.
Co-authored-by: Tracy <tracy.hertneky@noaa.gov>
* Further refinement to the tables and logs.

* Further refinement to the tables and logs. (NOAA-EMC#455)
Fixes the doxygen warnings in CALHEL.f CALHEL2.f CALHEL3.f

Please review this subroutine. Thank you.
* Unify the interfaces for reading FV3 outputs in netcdf.

* Remove interface INITPOST_GFS_NETCDF_PARA.

* Remove INITPOST_GFS_NETCDF.f.

* Remove the capability of serial netcdf reading FV3 outputs.

* Correct reading rswinc.

* Remove duplication in CLDRAD.f.

* Remove duplicated avgalbedo reading

* Add changes for reading pwat from model.

* Clean up commented out code

* Clean up duplicated lines
…e modulefiles for gnu and intel (NOAA-EMC#468)

* Add cheyenne modulefile

* Intel 19 --> 2021

* Add ability to specify compiler; move all existing modulefiles to ${name}_intel since they are all for intel compilers; add "cheyenne_gnu" modulefile

* Revert move of intel modulefiles; now the implicit default for a modulefile is intel, only gnu and other compilers will have the compiler name appended to the modulefile

* Allow for lua modulefiles with ".lua" appended
@SamuelTrahanNOAA
Copy link
Author

The module versions were out of date. I just updated them. Please try again.

@EricJames-NOAA
Copy link
Collaborator

@SamuelTrahanNOAA OK now I get a crash in UPP, looks like it is related to IFI:

/lfs4/BMC/wrfruc/ejames/RRFS/ptmp/com/logs/RRFS_CONUS/RRFS_conus_3km.20221129/15/run_post_f003_2022112915.log

@SamuelTrahanNOAA
Copy link
Author

That is the exact error I saw before I updated the library in the ifi branch.

@SamuelTrahanNOAA
Copy link
Author

Please recompile and try again. I'm certain the libraries are right this time because I deleted my working directory and the installed libraries, cloned again, and recompiled the libraries.

@hu5970
Copy link

hu5970 commented Jan 18, 2023

I can compile and run through with this PR. But there are couple of small differences between this PR and the RRFS UPP.
We can discuss those differences when Eric gets his case done.
Thanks,
Ming

@EricJames-NOAA
Copy link
Collaborator

@SamuelTrahanNOAA I'm still getting a crash. Is there some simple way I can test if the libraries are right in my setup?

@SamuelTrahanNOAA
Copy link
Author

At this point, I think I need to reproduce your failing test case to make any progress in fixing this.

@hu5970
Copy link

hu5970 commented Jan 19, 2023

@EricJames-NOAA Did you use standalone UPP or you put it under ufs APP to compile and run?

@EricJames-NOAA
Copy link
Collaborator

@EricJames-NOAA Did you use standalone UPP or you put it under ufs APP to compile and run?

I compiled standalone UPP, but then copied into ufs APP directory for my test setup. Here's the compile directory:

/lfs4/BMC/wrfruc/ejames/coding/UPP

@SamuelTrahanNOAA
Copy link
Author

You may be using the old IGET numbers if you used the app to run it.

@hu5970
Copy link

hu5970 commented Jan 19, 2023

@EricJames-NOAA In your test, the old IFI lib was used:
37) ifi/20220906-intel-18.0.5.274

You need to update the IFI for running:
/mnt/lfs4/BMC/wrfruc/ejames/coding/gsl-srweather-app/env/build_jet_intel.env

module use /lfs4/BMC/ifi/modulefiles
module load ifi/20220906-intel-18.0.5.274

You need to change to use the same IFI lib used for compiling:
ifi/20230118-intel-18.0.5.274

@EricJames-NOAA
Copy link
Collaborator

@hu5970 thanks catching that! My test is finished, the output looks identical except for a few additional fields which have been added to EMC develop branch. The IFI fields are slightly different, but it sounds like that is expected.

@SamuelTrahanNOAA
Copy link
Author

Can one of you do the necessary PR to the workflow to update its modules, xml, and txt?

@EricJames-NOAA
Copy link
Collaborator

Can one of you do the necessary PR to the workflow to update its modules, xml, and txt?

Yes I can do that!

@SamuelTrahanNOAA
Copy link
Author

Is this PR ready to be merged? Or are we waiting for something still?

@EricJames-NOAA
Copy link
Collaborator

Is this PR ready to be merged? Or are we waiting for something still?

Should we wait for the EMC develop PR to be merged to make sure they are consistent? Sounds like that PR may be almost ready for merging too.

@hu5970 may have had some things he wanted to discuss too.

@SamuelTrahanNOAA
Copy link
Author

Should we wait for the EMC develop PR to be merged to make sure they are consistent? Sounds like that PR may be almost ready for merging too.

Right, yes, I forgot that I just added a fix to that one which I haven't merged here yet.

Perhaps we should wait until the other PR is merged first. Yes.

@SamuelTrahanNOAA
Copy link
Author

I just removed a redundant loop that two people found.

@hu5970
Copy link

hu5970 commented Jan 19, 2023

My test shows all fields from this PR are good. But my test shows some differences in grib2 table information:

  1. 2n record in nat file: CLMR becomes CLWMR (no this name in grib2 table).
  2. 18 record in nat file:
    Old: MASSDEN Mass Density (Concentration) [kg/m^3]:aerosol=Particulate Organic Matter Dry::
    New: MASSDEN Mass Density (Concentration) [kg/m^3]:chemical=Particulate Organic Matter Dry:aerosol_size ??? code_table_4.91=255:aerosol_wavelength ??? code_table_4.91=255

New (record 1304):5000-2000 m above ground:0-1 hour min fcst:var discipline=0 center=7 local_table=1 parmcat=7 parm=200
Old (record 1303): 5000-2000 m above ground:0-1 hour min fcst:MNUPHL Hourly Minimum of Updraft Helicity [m^2/s^2]:
4)

Old( reocrd 1529): NLAT Latitude (-90 to 90) [deg]:
New(record 1529): NLAT Latitude (-90 to 90) [&NOAA-EMC#176]

5): record 1537 and beyond:
New: var discipline=3 center=7 local_table=1 parmcat=192 parm=20
Old: SBTA168 Simulated Brightness Temperature for ABI GOES-16, Band-8 [K]:

Those are cause by grib2 table or definition in control (NT) files. Could we double check if those differences are intended?

@SamuelTrahanNOAA
Copy link
Author

The tables match EMC develop, except for adding the ifi fields, and changing the precision of VIL_ON_ENTIRE_ATMOS.

@EricJames-NOAA
Copy link
Collaborator

@hu5970 are these differences from comparing Sam's branch with EMC develop? I don't see any differences when I compare Sam's branch with our realtime GRIB2 files, for example this file:

~rtrr/rrfs/v0.3.2/stmp/2023011917/postprd/RRFS_CONUS.t17z.bgrd3df001.tm00.grib2

@hu5970
Copy link

hu5970 commented Jan 19, 2023

@EricJames-NOAA Those are difference between Sam's executable and real-time executable. Also, the NT file for Sam's code was changed to one in PR. Let me try another run with old NT file.

@hu5970
Copy link

hu5970 commented Jan 19, 2023

I was using wrong executable to run the test. Now, everything looks good. Please merge the PR.

@hu5970
Copy link

hu5970 commented Jan 19, 2023

@EricJames-NOAA Please update the workflow to use this new UPP.

@SamuelTrahanNOAA SamuelTrahanNOAA merged commit 45de18a into NOAA-GSL:RRFS_dev Jan 19, 2023
@SamuelTrahanNOAA
Copy link
Author

I have merged it. Eric will need to check the latest RRFS_dev branch head to get the hash.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.