-
Notifications
You must be signed in to change notification settings - Fork 319
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
Make separate instantaneous and non-inst. history tapes #2445
base: master
Are you sure you want to change the base?
Conversation
...and other mods that I'm preserving from closed PR ESCOMP#2019, such as - changes to long_names and - treating avgflag as a tape (not field) trait for 'I' and 'L' tapes
This far I have tried one test: |
Conceptually, this seems like a good idea. Practically, this seems like a heavy lift. |
I think that consistency in the component output of CESM3 is quite important from a user's standpoint. CTSM would be an outlier amongst the 4 major components if these changes were not implemented. Looking at the project page, these changes have already been put into CAM and CICE. MOM came with these settings out of the box. @slevis-lmwg has a couple of pull requests with these changes for MOSART and RTM. I am a bit unclear where CISM is on implementing this. The only component that I know of that will likely not be implementing this is WW. |
I started to write a reply but @phillips-ad beat me to it. The critical piece of this is fixing time values for time-averaged fields so that the time is in the middle of the averaging period instead of at the end. As @phillips-ad says, it is likely to be particularly confusing if CTSM (and the river components) differs from other components in this respect. The separation of instantaneous from time-averaged fields is not a critical piece of this, but seemed like the best way to support having correct time values for both time-averaged fields and instantaneous fields. |
@billsacks I find the distinction in priority between the "middle of averaging period" task and the "separating instantaneous and non" task very helpful, because the former will take me a few days at most, while the latter will take me a few weeks at least. |
Thanks, that's good to know, @slevis-lmwg . I'm curious what the plan is, then, for instantaneous fields? Will you just let the time be incorrect for those fields for now? @phillips-ad do you agree that getting time correct for the time-averaged fields is the high priority thing here even if instantaneous fields aren't handled ideally for now? |
Yes I 100% agree, getting the time set to the middle of the averaging period for time-averaged fields is the higher priority. |
Just wanted to add: Separating instantaneous and time-averaged fields will probably be an issue for #2061, which adds a namelist option to enable all our history fields and put them all on the h0 file. Depending on which PR comes in first, we'll have to think about how we want to handle that. |
Thank you for pointing this out @samsrabin |
Yes, we will let the instantaneous fields be incorrect to start with. And then a later more involved change will fix that. I like the way that @samsrabin framed this when we discussed this. Right now "I" fields are correct, but "A" fields are incorrect. But, we care more about "A" fields (there's more of them output and they are the standard for most things) so getting them corrected at the expense of "I" fields is an improvement. |
Reduce outputs from matrixcnOn tests slevis resolved conflicts: src/main/histFileMod.F90
This comment was marked as resolved.
This comment was marked as resolved.
As part of work on #2838, I've added:
As part of this PR, the python code can be simplified to remove the non-instantaneous tape handling (where there's an option for both). Those new SystemTests can also be removed. |
Bring in several fixes for testing in the previous cesm3_0_beta03/04 tags Fix a list of issues mostly for testing that came in with the cesm3_0_beta03 and cesm3_0_beta04 tags for the science "chill" deadline bringing in the baseline science capabilities needed for the cesm3_0 release. List of things: - New polarcap grid - Fix use_init_interp for several resolutions that had problems - Remove clm5_1 physics option - Newly needed surface datasets added to auto build in Makefile for mksurfdata_esmf - Fix several individual tests that were failing - Update to submodules to ones roughly based on cesm3_0_beta04 - Add graceful error checking to the FATES parameter file tests that will get it working in some cases
@@ -49,6 +49,7 @@ module histFileMod | |||
integer , public, parameter :: scale_type_strlen = 32 ! maximum number of characters for scale types |
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.
integer , public, parameter :: scale_type_strlen = 32 ! maximum number of characters for scale types | |
integer , private, parameter :: scale_type_strlen = 32 ! maximum number of characters for scale types |
- As far as I can tell this parameter could be declared private.
- The 3 public parameters above it get used outside of histFileMod.
- In the context of this PR, do I need to worry about the corresponding section of code in src/utils/clmfates_interfaceMod.F90 which looks at fincl statements for FATES vars? Follow up.
src/main/histFileMod.F90
Outdated
@@ -402,6 +412,7 @@ subroutine hist_printflds() | |||
! the CTSM's web-based documentation. | |||
|
|||
! First sort the list to be in alphabetical order | |||
! TODO Is t = 1 argument needed? | |||
call sort_hist_list(1, nallhistflds, allhistfldlist) |
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.
call sort_hist_list(1, nallhistflds, allhistfldlist) | |
call sort_hist_list(nallhistflds, allhistfldlist) |
As far as I can tell, the t = 1 argument and later the plain t argument serve no purpose in subroutine sort_hist_list.
I got brave and submitted a test: See errors in the bld.log: |
This commit does not resolve all the errors
These three tests finish successfully, though I have not started looking at history output:
This longer test (See write-statements in latest test in /glade/derecho/scratch/slevis) This Lm2 test passed here: |
The same Lm2 test continues to pass with the latest commits AND it correctly separated an 'I' field from the rest (this may be the only default active 'I' field). Time-related fields also look correct but their metadata appear wrong... |
The latest problem that I have spotted: UPDATE
NEXT
|
Description of changes
I started from issue #1059 and PR #2019 and am restarting here. From closed PR #2019 I preserved a few things:
In this PR we also intend to split all history tapes into instantaneous and non-instantaneous. The CAM group accomplished this in PR ESCOMP/CAM#903 and we plan to maintain consistency in the appearance of CLM and CAM history files.
UPDATE
Due to higher priority, changing "time" to equal the middle of time_bounds will now get done in
#2838
ESCOMP/MOSART#106
ESCOMP/RTM#39
Specific notes
Contributors other than yourself, if any:
@ekluzek @billsacks
CTSM Issues Fixed (include github issue #):
Fixes #1059
Are answers expected to change (and if so in what way)? No
Any User Interface Changes (namelist or namelist defaults changes)?
We intend to split all history tapes into instantaneous and non-instantaneous.