-
Notifications
You must be signed in to change notification settings - Fork 134
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
Add dorebin and docleanup optional arguments to icepack_step_ridge #503
Conversation
This is a draft PR based on https://github.com/ESMG/Icepack/tree/optional_cleanup. See #478. Do we need new namelist (in Icepack and CICE) to allow users to turn the features on and off or will this just be hardcoded in the calls when needed? I am totally open to using different argument names if anyone wants something different. |
Since we generally would not recommend these flags be set to false, I do not think they should be exposed in namelist. |
Since it's pertinent, please also remove the reference to a boundary call mentioned here. It's around line 742 in ice_itd.F90. I looked in the old svn repository -- that comment is ANCIENT (more than 20 years). |
I don't understand it, but I can reproduce my old answers if I add yet a third optional argument to icepack_step_ridge. If the third one is false, I call ridge_ice without the opening and closing arguments, forcing it to call ridge_prep. I thought I was doing all the same computations on the SIS2 side, but something is still different. If chinook ever comes back, I'll have a better shot at debugging it. |
I figured it out - it's all in the order of operations. I approve this PR. |
@kshedstrom Great to hear you figured out what's going on. So do you need both of these optional arguments to make things work? Do you understand why? |
No, I only need the one, but I can get three different answers by having both. I haven't talked to the GFDL folks about this and maybe down the road we'll be able to pick which answer we want, but so far we've only tested it in long runs without any itd_cleanup at all. |
if (present(dorebin)) then | ||
ldorebin = dorebin | ||
else | ||
ldorebin = .true. |
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.
ldorebin
does not appear to be used in this subroutine
It is passed through to cleanup_itd. |
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.
Ah, now I see ldorebin
in the cleanup_itd
argument list. Thanks for the clarification. I'm still a bit hesitant to approve these changes without understanding what it is about the driver that requires them. I'm worried about nonphysical results that might not be noticed or accounted for. But I will approve, since these changes seem important for the GFDL model, and because these options are buried in the code where others are less likely to thoughtlessly experiment with them. If they turn out to be helpful for other groups, then we can expose them in namelist. I highly recommend the GFDL model's developers look closely at how their model handles ice thicknesses that lie outside of their thickness bins, especially considering @kshedstrom's comment that
I only need the one, but I can get three different answers by having both.
@kshedstrom @eclare108213 I am a little concerned that we don't fully understand why we need these changes and whether the science results are valid. I'm willing to merge this mostly because the feature is pretty well hidden, although the new arguments will appear in our Icepack interface documentation. @kshedstrom please confirm again that you want these changes as currently implemented in the PR to be merged and that you will continue to validate and report back any results to us. Thanks. |
Yes, this is indeed what I want, at least for now. In the MOM6 world having the ability to reproduce old answers can be important and we need one flag for that. I will let you know about the rest as I learn more. |
… support NOT calling cleanup_itd and NOT calling rebin in the ridge_ice. Closes CICE-Consortium#478
I ran full test suites on Derecho with intel and gnu for Icepack and CICE, tests look good. |
PR checklist
Add dorebin and docleanup optional arguments to icepack_step_ridge
kshedstrom, apcraig
Tested Icepack and CICE on Derecho without the optional arguments, with the optional arguments set to true and with the optional arguments set to false. Icepack remained bit-for-bit in all cases (probably too few gridcells), CICE changed answers when the optional arguments were set to false. Otherwise results are bit-for-bit, but will do more testing before merging. Ran full test suites on Derecho with intel and gnu for Icepack and CICE just before merging, results look fine.
Add dorebin and docleanup optional arguments to icepack_step_ridge to support NOT calling cleanup_itd and NOT calling rebin in the ridge_ice.
Closes #478
Rename limit_aice_in argument in ridge_ice to limit_aice. This argument is not used in Icepack or CICE at the moment.
Based on https://github.com/ESMG/Icepack/tree/optional_cleanup
Update interface document