Skip to content
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 ePBL bottom boundary layer mixing option #717

Merged
merged 6 commits into from
Dec 12, 2024

Conversation

Hallberg-NOAA
Copy link
Member

@Hallberg-NOAA Hallberg-NOAA commented Sep 4, 2024

This series of six commits adds the option to do energetically consistent bottom boundary layer mixing with the new routine ePBL_BBL_column(). ePBL_BBL_column() is closely based on the surface-focused ePBL mixing in ePBL_column(), but without adding convective instability driven mixing or mean-TKE driven mixing to avoid possible double-counting. This new option is enabled by setting the new runtime parameter EPBL_BBL_EFFIC to be positive. The changes include the addition of a new mandatory vertvisc_type argument to the publicly visible routine energetic_PBL(). If both EPBL_BBL_EFFIC and BBL_EFFIC are set to positive values, there is a risk of double-counting, but this case is not being trapped for now. The changes that actually adds ePBL_BBL_column() is in the fifth of the commits in this PR.

The first commit in this series corrects a bug that causes ePBL column to set the wrong variable and then use an uninitialized variable when EPBL_ORIGINAL_PE_CALC is set to false. This bug was present when the EPBL_ORIGINAL_PE_CALC was first added on Sept. 30, 2016, but it was not detected because only the default case with EPBL_ORIGINAL_PE_CALC = True appears to being used or tested. Any runs that used this code with debugging compile options would have trapped it immediately. This will change answers when EPBL_ORIGINAL_PE_CALC is false.

The second commit corrects an unlikely bug when iterating to determine the mixed layer depth, that arises when the change between iterations exactly matches the tolerance. This bug is fixed by setting the new runtime parameter EPBL_MLD_ITER_BUG = False.

The third commit adds the ability to passively run ePBL_column() twice in a diagnostic mode and then provide diagnostics of the differences in the diffusivities and boundary layer depths that are generated with the two options. This is controlled by the new runtime parameter EPBL_OPTIONS_DIFF, which is an integer that specifies which options to change or 0 (the default) to
disable this capability. Associated with this are the new diagnostics ePBL_opt_diff_Kd_ePBL, ePBL_opt_maxdiff_Kd_ePBL and ePBL_opt_diff_h_ML, which only are registered when the differencing is enabled.

There was also some refactoring for code clarity and clean-up of some typos as a part of this third commit. Within ePBL_column(), the hp_a variable was converted from a scalar into a 1-d array to emphasize where these variables are
located and to bring ePBL_column() closer to what would be required if the new diffusivities were being applied on top of diffusivities from other processes, as is the case in ePBL_BBL_column(). As a part of these changes, there were some other reforms to the way that MOM_energetic_PBL() handles diagnostics, with the 2-d and 3-d arrays changed from allocatable arrays with enduring memory commitments in the energetic_PBL_CS type into simple arrays in energetic_PBL(),
relying on the fact that compilers will be smart enough to avoid actually allocating this memory when it is unused to avoid expanding the overall memory requirements of MOM6. A number of allocate and deallocate calls were eliminated
by these changes. In addition, explicit 'units=' descriptors were added to numerous register_diag_field() calls to help identify inconsistent conversion factors. Also, the diagnostic of the number of boundary layer depth iterations
was added to the ePBL_column_diags, which enabled the intent of the CS and G arguments to ePBL_column() to be changed to intent(in). The unnecessary extra logic associated with the use of the OBL_converged variable in ePBL_column() was eliminated, but the results are unaltered. Because the MOM_parameter_doc files were changing anyway, and because this commit is only a diagnostic change, about 6 spelling errors were corrected in ePBL parameter descriptions as a part of
this commit.

The fourth commit adds the new internal subroutine find_Kd_from_PE_chg() inside of the MOM_energetic_PBL module to directly calculate an increment in the diapycnal diffusivity from an energy input. This can be used when ePBL does not convert
released mean kinetic energy into turbulent kinetic energy (i.e., if MKE_TO_TKE_EFFIC = 0.) and is more efficient than the more general iterative approach. To preserve old answers, this new option is only enabled for the surface boundary layer when the new runtime parameter DIRECT_EPBL_MIXING_CALC is set to true. This new option can be tested passively by setting
EPBL_OPTIONS_DIFF = 3 in a run that uses ePBL. ePBL_BBL_column() also has the option to use find_Kd_from_PE_chg(), and to verify its correctness for the bottom boundary layer by setting EPBL_OPTIONS_DIFF = 4.

The sixth and final commit adds the ability to modify the bottom boundary layer TKE budget to account for an exponential decay of TKE away from the boundary and the fact that when the diffusivity is increased at an interface, it causes an increased buoyancy flux that varies linearly throughout a well mixed bottom boundary layer and through the layer above. This new capability is enabled by the new runtime parameter DECAY_ADJUSTED_BBL_TKE and is implemented via the new internal function exp_decay_TKE_adjust. It also adds 9 bottom-boundary layer specific run-time parameters that are analogous to parameters that set the properties of the surface-driven mixing, and take their defaults from them, but can now be set independently for the bottom boundary layer.

This PR makes several new diagnostics available that are related to bottom boundary layer mixing or the sensitivity of ePBL mixing to several parameter changes. The MOM_parameter_doc files are altered by the addition of up to 15 new runtime parameters, and by the correction of several spelling errors in the descriptions of other ePBL parameters. By default, all answers are bitwise identical.

This commits in this PR include:

  • 80c2fc560 +Add DECAY_ADJUSTED_BBL_TKE option for ePBL BBL
  • 0c17f5fb2 +(*)Add ePBL bottom boundary mixing option
  • 6f2c5fd35 +Add and test find_Kd_from_PE_chg
  • 92f30322e +Add run-time ability to debug ePBL sensitivities
  • 972f8e3ee +Add EPBL_MLD_ITER_BUG runtime parameter
  • 49414ac36 *Fix a bug when EPBL_ORIGINAL_PE_CALC is false

@Hallberg-NOAA Hallberg-NOAA added bug Something isn't working enhancement New feature or request answer-changing A change in results (actual or potential) Parameter change Input parameter changes (addition, removal, or description) labels Sep 4, 2024
@Hallberg-NOAA
Copy link
Member Author

I am converting this to a draft PR , because while I believe that it is correct (and worth assessing), I think that it could be made much more efficient. We are not using released mean kinetic energy to drive added bottom boundary layer mixing, which means that we can solve directly for the diffusivity that can be supported by a given energy increment without having to do so iteratively with Newton's method.

@Hallberg-NOAA Hallberg-NOAA marked this pull request as draft October 1, 2024 17:09
@Hallberg-NOAA Hallberg-NOAA marked this pull request as ready for review November 22, 2024 20:01
@Hallberg-NOAA Hallberg-NOAA added the documentation Improvements or additions to documentation label Nov 22, 2024
@Hallberg-NOAA
Copy link
Member Author

This PR has now been revised into its complete form, and ready for review. Please do not squash this PR, as each of the 5 commits that comprise this PR are significant, either in their scope or by fixing a bug.

@Hallberg-NOAA Hallberg-NOAA force-pushed the add_ePBL_BBL branch 2 times, most recently from ca009da to 6b9b0d9 Compare November 30, 2024 16:02
adcroft
adcroft previously approved these changes Dec 2, 2024
Copy link
Member

@adcroft adcroft left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks good to me. Wondering is @breichl should also look at this?

@Hallberg-NOAA
Copy link
Member Author

This PR has been updated with one final commit to allow for the bottom boundary layer parameters to be specified separately from the surface boundary layer parameters, and to adjust the energetics of the bottom boundary layer mixing to account for the exponential decay of the bottom-driven TKE away from the bottom.

@adcroft adcroft dismissed their stale review December 4, 2024 13:57

We decided at the Monday morning dev meeting that Brandon would review

Copy link

@breichl breichl left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is a well needed addition to MOM6-ePBL for having the BBL parameterization consistent with the OSBL. We should consider building off of this to enable m* functionality as another option for setting the energetics of the BBL mixing. However, I think this PR should be merged and tested as-is, and consideration of other parameterizations for the mixing energy can be added to this in the future.

I noted one very minor caps-lock typo, but did not spot any obvious necessary changes.

src/parameterizations/vertical/MOM_energetic_PBL.F90 Outdated Show resolved Hide resolved
Copy link
Member

@adcroft adcroft left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

When you change MAX -> max, if you rebase at the same time it will save time when pushing this through the pipeline

@adcroft
Copy link
Member

adcroft commented Dec 11, 2024

PS> Feel free to push the revised pr/717 to the pipeline overnight (at 4am?) so I can just click some buttons in the morning.

  Corrected a bug that causes ePBL column to set the wrong variable and then use
an uninitialized variable when EPBL_ORIGINAL_PE_CALC is set to false.  This bug
was present when the EPBL_ORIGINAL_PE_CALC was first added on Sept. 30, 2016,
but it was not detected because only the default case with EPBL_ORIGINAL_PE_CALC
= True appears to being used or tested.  Any runs that used this code with
debugging compile options would have trapped it immediately.  This will change
answers when EPBL_ORIGINAL_PE_CALC is false.
  Added the new runtime parameter EPBL_MLD_ITER_BUG that can be set to false to
correct buggy logic that gives the wrong bounds for the next iteration  when
USE_MLD_ITERATION is true and successive guesses increase by exactly
EPBL_MLD_TOLERANCE.  By default all answers are bitwise identical, but there is
a new runtime parameter in some MOM_parameter_doc files.
  Added the ability to passively run ePBL_column twice in a diagnostic mode and
then provide diagnostics of the differences in the diffusivities and boundary
layer depths that are generated with the two options.  This is controlled by the
new runtime parameter EPBL_OPTIONS_DIFF, which is an integer that specifies
which options to change or 0 (the default) to disable this capability.
Associated with this are the new diagnostics ePBL_opt_diff_Kd_ePBL,
ePBL_opt_maxdiff_Kd_ePBL and ePBL_opt_diff_h_ML, which only are registered when
the differencing is enabled.  For now, only changes associated with the settings
of EPBL_ORIGINAL_PE_CALC and EPBL_ANSWER_DATE can be evaluated, but this list
will grow as new options are added.

  As a part of these changes, there were some other reforms to the way that
MOM_energetic_PBL handles diagnostics, with the 2-d and 3-d arrays changed from
allocatable arrays with enduring memory commitments in the energetic_PBL_CS type
into simple arrays in energetic_PBL, relying on the fact that compilers will be
smart enough to avoid actually allocating this memory when it is unused to avoid
expanding the overall memory requirements of MOM6.  A number of allocate and
deallocate calls were eliminated by these changes.

  In addition, explicit 'units=' descriptors were added to numerous
register_diag_field calls to help identify inconsistent conversion factors.

  Also, the diagnostic of the number of boundary layer depth iterations was
added to the ePBL_column_diags, which enabled the intent of the CS and G
arguments to ePBL_column to be changed to intent(in).  The unnecessary extra
logic associated with the use of the OBL_converged variable in ePBL_column was
eliminated, but the results are uneffected.

  Because the MOM_parameter_doc files were changing anyway, and because this
commit is only a diagnostic change, about 6 spelling errors were corrected in
ePBL parameter descriptions as a part of this commit.

  All answers are bitwise identical, but there is a new runtime parameter and
there may be new diagnostics depending on the choice of a non-default value for
that new parameter.
  Added the new internal subroutine find_Kd_from_PE_chg inside of the
MOM_energetic_PBL module to directly calculate an increment in the diapycnal
diffusivity from an energy input.  This can be used when ePBL does not convert
released mean kinetic energy into turbulent kinetic energy (i.e., if
MKE_TO_TKE_EFFIC = 0.) and is more efficient than the more general iterative
approach.  To preserve old answers, this new option is only enabled for the
surface boundary layer when the new runtime parameter DIRECT_EPBL_MIXING_CALC is
set to true.  This new option can be tested passively by setting
EPBL_OPTIONS_DIFF to 3 in a run that uses ePBL.  By default all answers are
bitwise identical, but there is a new runtime parameter in some of the
MOM_parameter_doc files.
  Add the option to do energetically consistent bottom boundary layer mixing
with the new routine ePBL_BBL_column.  ePBL_BBL_column is closely based on the
surface-focused ePBL mixing in ePBL_column, but without adding convective
instability driven mixing or mean-TKE driven mixing to avoid possible
double-counting.  This new option is enabled by setting the new runtime
parameter EPBL_BBL_EFFIC to be positive.

  If both EPBL_BBL_EFFIC and BBL_EFFIC are set to positive values, there is a
risk of double-counting, but this case is not being trapped for now.

  The changes include the addition of a new mandatory vertvisc_type argument to
the publicly visible routine energetic_PBL.

  When this new ePBL bottom boundary layer mixing option is enabled, there are
several new diagnostics available that are related to bottom boundary layer
mixing.  Several new checksum calls were also added with this new option when
DEBUG = True. The MOM_parameter_doc files are altered by the addition of two new
runtime parameters, and by the correction of several spelling errors in the
descriptions of other ePBL parameters.  By default, all answers are bitwise
identical.
  Added the ability to modify the bottom boundary layer TKE budget to account
for an exponential decay of TKE away from the boundary and the fact that when
the diffusivity is increased at an interface, it causes an increased buoyancy
flux that varies linearly throughout a well mixed bottom boundary layer and
through the layer above.  This new capability is enabled by the new runtime
parameter DECAY_ADJUSTED_BBL_TKE and is implemented via the new internal
function exp_decay_TKE_adjust.

  In addition, this commit adds 9 bottom-boundary layer specific run-time
parameters that are analogous to parameters that set the properties of the
surface-driven mixing, and take their defaults from them, but can now be set
independently for the bottom boundary layer.  The inefficient option to use
bisection to estimate the bottom boundary layer depth was eliminated, as it
certain that it is not being used yet in any cases, and it should be deprecated
for the estimation of the surface boundary layer.

  By default, all answers are bitwise identical, but there are up to 10 new
runtime parameters that will appear in some MOM_parameter_doc files.
@Hallberg-NOAA
Copy link
Member Author

The pipeline testing was just triggered for this PR. (Sorry, but this was 29 minutes later than you had requested it.)

@adcroft adcroft merged commit d8a270b into NOAA-GFDL:dev/gfdl Dec 12, 2024
10 checks passed
@Hallberg-NOAA Hallberg-NOAA deleted the add_ePBL_BBL branch January 14, 2025 18:45
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
answer-changing A change in results (actual or potential) bug Something isn't working documentation Improvements or additions to documentation enhancement New feature or request Parameter change Input parameter changes (addition, removal, or description)
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants