-
Notifications
You must be signed in to change notification settings - Fork 177
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
Update scripts to use the GW-RT global namelist #3017
base: develop
Are you sure you want to change the base?
Conversation
Not a fan of the hiding, at least not how it is implemented here. All the variables are still set by the parsing script, it makes the template more difficult to read, and doesn't even remove it from the rendered namelist, just comments the lines out. Given that, I'd rather just leave all the settings in the namelist with the values that turn them off. |
Hey Walter, Splitting up the sections into different scripts could also work, but you run into the issue of not being able to easily pass variables between scripts if they are saved as locals (correct me if I'm wrong here). Also open to your suggestions on how to best make this fit within the GW system. |
Here is a doc with the differences between variable values for GW and RT for a C48 atm only case: GW-RT differences We're leaning towards just changing the RT baselines to match what GW has, but we can discuss this if needed. |
ush/parsing_namelists_FV3.sh
Outdated
local NPZP=${LEVS} #levp | ||
local GFS_DWINDS=${gfs_dwinds} | ||
|
||
local FHZERO=${FHZER} |
Check notice
Code scanning / shellcheck
Possible misspelling: FHZER may not be assigned. Did you mean FHZERO? Note
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Old script saved this as FHZER (ush/parsing_namelists_FV3.sh L196). Kept the convention for now.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We should just update the other instances:
parm/config/gfs/config.efcs:export FHZER=6
parm/config/gefs/config.fcst:export FHZER=@FHZER@
parm/config/gefs/yaml/defaults.yaml: FHZER: 6
ush/parsing_namelists_FV3_nest.sh: fhzero = ${FHZER}
51ecf63
to
6c5b9bb
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Structurally it looks fine. Didn't verify that the default for every individual setting is unchanged. Just take care of the FHZER
thing and I'm happy with this.
ush/parsing_namelists_FV3.sh
Outdated
local NPZP=${LEVS} #levp | ||
local GFS_DWINDS=${gfs_dwinds} | ||
|
||
local FHZERO=${FHZER} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We should just update the other instances:
parm/config/gfs/config.efcs:export FHZER=6
parm/config/gefs/config.fcst:export FHZER=@FHZER@
parm/config/gefs/yaml/defaults.yaml: FHZER: 6
ush/parsing_namelists_FV3_nest.sh: fhzero = ${FHZER}
@dpsarmie Merge in develop again and I think this is ready for CI |
I was still running tests on my end as a final check but should be done before lunch. We should still talk about the final pathing to the template (just added a review for visibility). |
Added a missing period
@WalterKolczynski-NOAA Ok, good to go on my end pending the needed pathing change. I added a google sheet to the PR desc to document the variables that are new to the GW template and all pre-existing values are unchanged. It'll be easier see the changes in case they are needed. |
The templates should be linked into |
Ok, got it going but ran into another issue. The hash GW is using (63ace62) is using a namelist template with the [HIDE_X] tags and is incompatible with the script based off the current namelist template. I can add the HIDE_X definitions back in and then they would be removed next time GW updates the UFS hash? We could also just sit on this PR until the next hash update. Let me know what you think makes sense. |
#3190 updates the ufs model hash, so it shouldn't be too long a wait. |
Description
The following is a Google Doc with new variables that were added to the nml template with this PR: Google Sheets link
This PR changes the ways the input.nml file is created. Instead of creating a namelist, the variables that are set locally will now use the UFS
global_control.nml.IN
template and the atparse function to generate the namelist.This should allow the GW branch to more easily test changes in the UFS regression test framework. It will also allow GW to more easily introduce UFS changes into GW.
The functionality in
parsing_namelists_FV3.sh
is mostly unchanged. Since variables are still saved aslocal
, the parsing of the template will occur in this script. Sections in the namelist that were previously not generated (stoch physics options for example) will be set and parsed since the regression test template has these placeholders active. As options are turned off and on, ! will be used in the namelist to comment out sections that are not used.Previous PR #2733 was closed since my old branch was stale and a new branch was created.
Unresolved issues and input needed from GW group before final code review
First of all,
global_control.nml.IN
has been added in the root directory of global_workflow. This will not be in the final commit. This is a place holder until the pathing to the UFS template is finalized. A variable with the final path will also be needed to replace the hardcoded path inparsing_namelists_FV3.sh
.There are some variables that were not set in the original scripts that have been added. These were set to the UFS defaults.
The tests I've conducted were to generate the namelists but more tests should be done to make sure that outputs have not changed.
Resolves #2731
Resolves ufs-community/ufs-weather-model#1664
Outstanding dependencies:
ufs-community/ufs-weather-model#2425
Type of change
Change characteristics
How has this been tested?
Tested namelist generation with C48ATM and C48S2S configurations. Further testing will need to be done to ensure intended funcitonality.
Checklist