-
Notifications
You must be signed in to change notification settings - Fork 36
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 ozone physics CCPP compliant by removing 'optional' and 'pointer' attributes (includes #168 and #169) #150
Make ozone physics CCPP compliant by removing 'optional' and 'pointer' attributes (includes #168 and #169) #150
Conversation
… into bugfix/ozphys_ccpp_compliant
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.
@climbfuji Thanks for making this change.
My intention was to a) avoid using host logic to control scheme diagnostics, and b) add more flexibility over the diagnostics being requested (e.g output only a subset of the available diagnostics).
The idea being that if the host allocates (associates) them, the scheme knows to output them. But now that everything will be allocated to at least size(0), this logic doesn't work. We could change "if associated(var)" with "if size(var) > 0" or "if size(var) > 0" ? Thoughts?
Are these changes ready (everything allocated to at least size 0)? |
Not yet, but very soon I believe. @grantfirl Can you confirm? |
Yes, I have code with all conditionally-allocated variables now being allocated to size 0, but I ran into issues before the break with respect to switching variables from pointers to allocatables. GFS_diagnostics is assigning pointers to components of DDTs. This works fine with the DDT components being pointers, and it is apparently supposed to work fine with allocatables as long as the top level DDT (GFS_data_type in this case) is given the TARGET attribute (which it already has), but the compiler is still erring out and I don't really understand why. If we need this ASAP, I can put everything back to pointers that are still being allocated to zero size, but I was going to try to debug why it won't work as TARGET allocatables in GFS_diagnostics. |
We can discuss this at our next CCPP framework meeting, but: Even if we add the size-0 allocation, this is only a duct-tape solution so that the code compiles and runs without errors and warnings, as required by NCEP operations. This does not mean that we should throw overboard the rules and requirements that the CCPP framework developers came up with in the past, which are that conditionally allocated variables must have an active attribute (condition for allocation) in the host model metadata, and schemes must test for that condition in order to access the variable. If we want to change that, then I think we need to take this back to the CCPP framework developer meeting and discuss this in a broader context than just the UFS and NCEP operations. I personally think that we need to take this back to the drawing board and see if we can come up with a better solution altogether. But, for now, this PR is simply applying current CCPP rules and requirements and removing code that violates those rules. |
There are other solutions that could be applied instead of allocating to size(0):
I agree that this needs further discussion. TBH, I never really understood the spirit of the "active" attribute and I think it should be revisited. |
I agree! |
…bles not given an explicit value" warning. The following table provides justification for setting the variable to 0, it is how they are treated in other places. | file | line | description | |--------------------+------+-----------------------------| | ugwpv1_gsldrag.F90 | 521 | zlwb(:)= 0. ; zogw(:)=0. | | ugwp_driver_v0.F | 206 | zmtb(i) = 0.0 | | cires_ugwp.F90 | 297 | if (do_ugwp) zlwb(:) = 0. |
… drain_cpl and dsnow_cpl vars are changed from intent(out) to intent(in) variables. This is to replicate the rain_cpl and snow_cpl variables.
…out) variables. Variable err_message will report any errors in open and read statements
… into bugfix/ozphys_ccpp_compliant
… into bugfix/ozphys_ccpp_compliant
… into bugfix/ozphys_ccpp_compliant
…es/ccpp-physics into bugfix/ozphys_ccpp_compliant
@climbfuji Could you pull in #169? I've run RTs separately on it, and those changes also don't affect baselines. That way, we'll merge 3 PRs in one go. |
…hysics into bugfix/ozphys_ccpp_compliant
@grantfirl done. I also updated my set of PRs from the authoritative repositories and pushed the changes to all PRs. |
@grantfirl testing is complete on ufs-wm PR #2066. Can you please merge this PR? |
@dustinswales @climbfuji Thanks for merging, Dustin -- beat me to it. I'm glad to get these changes in finally. |
…run compile jobs of regression test suite only & -mcmodel=medium gnu.cmake option (also includes #2142) (#2066) * UFSWM - Add option to `rt.sh` to run compile-only tests * FV3 - Update submodule pointer (NOAA-EMC/fv3atm#747) * ccpp-physics - Update submodule pointer (ufs-community/ccpp-physics#150) * ccpp-framework - Update submodule pointer (NCAR/ccpp-framework#519) * Update WM license and documentation logo * Update GNU.cmake: -mcmodel=medium
Description
This PR is required to address issues with a recent PR to the physics (#75) that was not fully CCPP compliant. It introduced Fortran attributes
optional
andpointer
in the GFS_suite_stateout_update scheme, both of which are not permitted/supported by the current CCPP framework.The correct way to handle this situation, as described in the CCPP technical documentation and our recent paper (https://gmd.copernicus.org/articles/16/2235/2023/) is to pass the logical flag that is used in the
active
attribute and read/write from/to the arrays based on that flag.I will note that we need to address the way we handle inactive data in the near future and that this may or may not require (re-)introducing Fortran attributes thrown out here, but as of now the current code is invalid per CCPP requirements.
I also pulled in #168. and #169 per request from the repository managers. Please see these issues for the description of the respective changes.
Issues
This PR fixes #75 (comment)
Dependencies / associated PRs
This PR is part of a set of PRs that need to be tested and merged together:
Note that the CI tests fail due to an error unrelated to this PR (related to the CI scripts themselves): https://github.com/ufs-community/ccpp-physics/actions/runs/7334889268/job/19972125491?pr=150