-
Notifications
You must be signed in to change notification settings - Fork 132
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
Set 'idate0' and 'use_leap_years' in nuopc cap #936
Conversation
Do I understand correctly? In the CESM case, the In our case, we do set the appropriate |
I guess I don't understand these changes. We have code in init_calendar that sets idate0 from myear, mmonth, and mday. These are set in ice_comp_nuopc.F90. Similarly, we set the calendar_type in ice_comp_nuopc.F90, I guess technically we should set use_leap_years as well, but this is not used here. Dave
|
Ah, I see part of the problem. In ice_history_write.F90 we do the following. So, we do need to see use_leap_years = .true. This seems silly to me as we already have the variable calendar_type which we could use here.
|
I guess I am also confused when init_calendar is called. I guess myear, mmonth, mday are only set when runtype == 'initial'. I believe we intended it this way. However, it looks like init_calendar is called in cice_init2 (InitializeRealize). Then for an initial run only, it checks the year, month, day against the values from the coupler. However, it calls calendar and not init_calendar here, so it does not look like idate0 is reset after checking with the coupler. So, instead of adding this code to ice_comp_nuopc.F90, I think there should be a call to init_calendar in this code block. We should also add something in init_calendar that sets use_leap_years to true when calendar_type = 'GREGORIAN'. |
This is what is happening for ACCESS - getting the right time_origin time_units relied on configuring the same information in two places (cmeps and cice namelist).
Ok good, do we need these lines within a CESM_COUPLED then?
This change would overwrite the values set in the namelist with the values from ESMF (UFS probbably has then set the same already so it would have no impact?). |
The second block (overwriting the _init from the ESMF clock) is fine for us. That is how I tested it and the time axis came out identical. Our configuration script actually fills in these values appropriate for each run, so they end up being consistent. |
In this bit of code (from init_calendar) myear, mmonth and mday are set from year_init, month_init, day_init etc which are set from the cice namelist. init_calendar is called in cice_init2, which is before myear/mmonth/mday are updated in InitializeRealize.
I don't think this fixes the problem, init_calendar sets myear/mmonth/mday and idate0 from year_init/month_init/day_init and would therefore overwrite the coupler date with the defaults from the cice namelist. (Unless we set year_init/month_init/day_init in the driver before init_calendar is called.)
We can do this, but it feels neater to keep cmeps things in the cmeps driver? |
Perhaps. However, there is already an #ifdef CESMCOUPLED in ice_calendar.F90. |
Ok - i moved the setting of |
Also - we could probably address #842 at the same time as well if that is useful :) |
Actually, we should look at the sequence here. Is calendar_type set before calling init_calendar? If not, we should do it all in ice_comp_nuopc.F90. Thanks for finding this. |
Yeah the calendar is set before the namelist is read and before any init calls:
We can't set use_leap_years at the same line in code because it would be overwritten by ice_init. |
…n netcdf output is consistent with other model components. Set use_leap_years in nuopc cap, so that netcdf output "time:calendar" is set correctly in history output
Co-authored-by: Denise Worthen <[email protected]>
b64d07c
to
1ea0543
Compare
1ea0543
to
6e68ad2
Compare
@dabail10 What should we do with this? |
I think we set everything here in ice_comp_nuopc.F90 after the call to cice_init2. Basically as you had it. |
This reverts commit 6e68ad2.
Ok done. Can you review please? :) |
This change sets the 'time:units' and the 'time:calendar'' attributes of the history output consistent with the nuopc.runconfig file Patch is cherry-picked from CICE-Consortium/CICE#936
This change sets the 'time:units' and the 'time:calendar'' attributes of the history output consistent with the nuopc.runconfig file Patch is cherry-picked from CICE-Consortium/CICE#936
With CICE-Consortium/CICE#936 this is set by the nuopc driver
Set idate0 in nuopc cap, so that the history "time:units" attribute in netcdf output is consistent with other model components. Set use_leap_years in nuopc cap, so that netcdf output "time:calendar" is set correctly in history output Co-authored-by: Denise Worthen <[email protected]>
With CICE-Consortium/CICE#936 this is set by the nuopc driver
With CICE-Consortium/CICE#936 this is set by the nuopc driver
PR checklist
Short (1 sentence) summary of your PR:
Set 'idate0' and 'use_leap_years' in nuopc cap. The nuopc cap sets the calendar for CICE (rather than the normal namelist options), but these variables were missing. This means that the attributes of the time variable history output are incorrect in two ways:
time:units start from year 0000, which is not allowed if Gregorian calendar is used strictly (it starts in 1582 or so)
time:calendar is always 'noleap', even when it should be 'Gregorian'
Developer(s):
@anton-seaice
Suggest PR reviewers from list in the column to the right.
@DeniseWorthen @dabail10
Please copy the PR test results link or provide a summary of testing completed below.
I did adhoc testing, with the defaults in
ice_in
, a gregorian calendar in nuopc/cmeps and current CICE, on initial run, the time var looks like this:After the change:
runtype = 'initial'
runtype = 'continue'
How much do the PR code changes differ from the unmodified code?
Does this PR create or have dependencies on Icepack or any other models?
Does this PR update the Icepack submodule? If so, the Icepack submodule must point to a hash on Icepack's main branch.
Does this PR add any new test cases?
Is the documentation being updated? ("Documentation" includes information on the wiki or in the .rst files from doc/source/, which are used to create the online technical docs at https://readthedocs.org/projects/cice-consortium-cice/. A test build of the technical docs will be performed as part of the PR testing.)
Please document the changes in detail, including why the changes are made. This will become part of the PR commit log.
Set run start date (idate0) in nuopc driver, so that the history "time:units" attribute in netcdf output is consistent with the date set through nuopc.
Set use_leap_years in nuopc cap, so that netcdf output "time:calendar" is set correctly in history output (i.e. is correctly set as noleap / gregorian) for calendars set through the driver.