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

Feature/gfdlmpv3 (ready for review) #195

Open
wants to merge 44 commits into
base: ufs/dev
Choose a base branch
from

Conversation

dustinswales
Copy link
Collaborator

@dustinswales dustinswales commented Apr 3, 2024

Description (*updated on 11/18/2024)

This PR is intended to supersede #162
@RuiyuSun I refactored to code so that GFDL v1 and v3 share as much common code as possible.

For the refactoring, all of the configuration/namelist info is moved into a common module that is referenced by both MP versions and a shared fv_sat_adj.F90. There are default values for the scheme configurations defined within this module, and overwritten by the namelist, if provided. Both the v1 and v3 rely on some of the same parameters, but with different default values. This is handled by introducing a pre-processor directive into the new configuration module.

I also removed the imp_physics_gfdl_v3 flag. GFDL v1 and v3 have their own distinct namelists, so there is no need to have another switch to distinguish v1/v3.
The only differences to run with GFDLv1 or v3 are:

  • in the SDF: gfdl_cloud_microphys or gfdl_cloud_microphys_v3 and
  • which namelist is added to gfs_phys_nml: V1 nml or V3 nml
  • set new pre-processor directive, GFDLMP_v3, to true.

Testing

Tested on Hera using Intel
No changes to GFDL MP v1 enabled baselines (control_iovr4 and hafs_regional_atm)

@RuiyuSun
Copy link
Collaborator

RuiyuSun commented Apr 4, 2024

@dustinswales This is great and thanks!! I agree that the scheme name in SDF and different namelist name are enough to distinguish the two versions of the scheme. So I think it is good idea to remove the imp_physics_gfdl_v3 flag. Did you forget to remove the flag in the gfdl_cloud_microphysics_v3.F90 file?

What is next?

@dustinswales
Copy link
Collaborator Author

@RuiyuSun Good call. I just removed the flag from the scheme.

Next we need to test that the RTs that use GFDLMP v1 are unchanged (I can do this next week). I can't speak to how the v3 results should differ wrt v1 (I will leave this piece to you)

@RuiyuSun
Copy link
Collaborator

RuiyuSun commented Apr 4, 2024

@RuiyuSun Good call. I just removed the flag from the scheme.

Next we need to test that the RTs that use GFDLMP v1 are unchanged (I can do this next week). I can't speak to how the v3 results should differ wrt v1 (I will leave this piece to you)

@dustinswales Sounds good.

@RuiyuSun
Copy link
Collaborator

RuiyuSun commented Apr 9, 2024

@dustinswales How do I check out this code? Thanks!

@dustinswales
Copy link
Collaborator Author

@dustinswales How do I check out this code? Thanks!

git clone --recursive --branch feature/gfdlmpv3 https://github.com/dustinswales/ufs-weather-model.git

@dustinswales
Copy link
Collaborator Author

@grantfirl This is ready for review.

@dustinswales dustinswales changed the title TO DISCUSS: Feature/gfdlmpv3 Feature/gfdlmpv3 (ready for review) Nov 18, 2024
! GFDL MP common (v1/v3) parameters, with different default values
! #####################################################################################
#ifdef GFDLMP_V3
real(kind_phys) :: tice = 273.15 !< freezing temperature (K): ref: GFDL, GFS (DJS: V3=273.15)
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why does this need to be redefined from the one that is already provided by the host (temperature_at_zero_celsius)? Does it really make that much of a difference to 1) use a different value for each version and 2) use something different than the host and rest of physics?

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@grantfirl These are the defaults and (potentially) overwritten later on. I don't know if the 0.01K difference is by design or an oversight (I didn't want to add any changes when creating this module).
@RuiyuSun Does v3 need tice=273.16? or could we use 273.15?

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@dustinswales In v3 it is defined as 273.15.

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

According to the comment in the v3 code, 273.15 is used to be consistent with the value defined in other schemes in GFS


implicit none

! DH* TODO: CLEANUP, all of these should be coming in through the argument list
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yes, and consider the comment RE: temperature_at_zero_celsius

do k=1,levs
kk = levs-k+1
do i=1,im
if (imp_physics==imp_physics_gfdl) then
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why is this necessary? Shouldn't the check above already have been executed and returned with an error if imp_physics is wrong?

!***********************************************************************
!* GNU Lesser General Public License
!*
!* This file is part of the FV3 dynamical core.
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It's a little weird to have this in a physics scheme in the CCPP, but I'm guessing that it's not our call.

! physics constants
! -----------------------------------------------------------------------

real, parameter :: grav = 9.80665 ! acceleration due to gravity (m/s^2), ref: IFS
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yikes. Lots of redefining constants here. Why does GFDL MP need to have a different gravity or pi than the host or rest of physics?

real, parameter :: eps = rdgas / rvgas ! 0.6219934994582882
real, parameter :: epsm1 = rdgas / rvgas - 1. ! -0.3780065005417118

real, parameter :: tice = 273.15 ! freezing temperature (K): ref: GFDL, GFS
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is double redefining. It was redefined in the GFDL MP specific module then redefined here. Why?

! major cloud microphysics driver
! -----------------------------------------------------------------------

call mpdrv (hydrostatic, ua, va, wa, delp, pt, qv, ql, qr, qi, qs, qg, qa, &
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is another scheme with 3 layers of drivers. Not ideal, but I assume that there is a good reason to keep all of them?

! unit convert to mm/day
! -----------------------------------------------------------------------

convt = 86400. * rgrav / dts
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

redefining # of seconds in a day

if (consv_checker) then
if (abs (sum (te_end_d (i, :)) + te_b_end_d (i) - sum (te_beg_d (i, :)) - te_b_beg_d (i)) / &
(sum (te_beg_d (i, :)) + te_b_beg_d (i)) .gt. te_err) then
print*, "GFDL-MP-DRY TE: ", &
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Consider wrapping print statements with a debug flag to reduce standard out spam for normal execution.

case ("qg")
q = qg
case default
print *, "gfdl_mp: qflag error!"
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Should one pass down and set ccpp_err_msg and ccpp_err_flag and return? Or is this error not that egregious?

case ("qg")
qg (k) = q (k)
case default
print *, "gfdl_mp: qflag error!"
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Same question RE: error handling

case ("qg")
q = qg
case default
print *, "gfdl_mp: qflag error!"
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Same question RE: error handling

case ("qg")
q = qg
case default
print *, "gfdl_mp: qflag error!"
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Same question RE: error handling

case ("qg")
qg = q
case default
print *, "gfdl_mp: qflag error!"
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ditto

a4 (4, n) * r3 * (pr * (pr + pl) + pl ** 2)
qm (k) = qm (k) * (ze (k) - ze (k + 1))
k0 = n
goto 555
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

GOTOs are generally frowned upon for CCPP schemes. Consider trying to use a different control structure if possible.

te (k) = rgrav * te (k) * delp (k)
tw (k) = rgrav * (qv (k) + q_cond) * delp (k)
enddo
te_b = (dte + (lv00 * c_air * vapor - li00 * c_air * (ice + snow + graupel)) * dts / 86400 + sen * dts + stress * dts)
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

redefining # of seconds in a day again

@grantfirl
Copy link
Collaborator

@RuiyuSun @dustinswales I finished my initial review. Mostly minor comments. The biggest things for me are that there are a lot of physical constants being redefined that are introducing potential inconsistencies with the rest of the code base (host and rest of physics) and the potential need to extend CCPP error handling downward into the actual physics code to catch and return errors. Overall, nice job! I don't see anything that absolutely HAS to be changed, although addressing my comments would definitely help CCPP compatibility.

Copy link
Collaborator

@grantfirl grantfirl left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm putting a "request changes" review on this. I'm not saying that all my comments need to lead to code changes -- explanations for why they can't change can also suffice, and I'll approve at that time.

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.

3 participants