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

Making validation and verification more portable #299

Open
3 tasks
RobertPincus opened this issue Oct 30, 2024 · 1 comment
Open
3 tasks

Making validation and verification more portable #299

RobertPincus opened this issue Oct 30, 2024 · 1 comment

Comments

@RobertPincus
Copy link
Member

Verification and validation have grown organically with the code base. At this time this include

  • (verification) unit tests for RTE optical properties and solvers in tests
  • (verification) invariance tests for gas optics + solvers in tests
  • (evaluation) exploration of alternatives (e.g. reduced numbers of g-points, number of quadrature angles) with tests/check_variants
  • (validation1) ability to reproduce clear-sky fluxes and compare to benchmarks over a wide range of conditions in examples/rfmip-clear-sky
  • (validation1) ability to reproduce all-sky fluxes examples/allsky

To prepare for alternative implementations of gas optics we might want to isolate the specific dependencies of the tests and examples on RRTMGP. This has been done for the gas optics in tests by encapsulating the gas optics type and its initialization in mo_gas_optics_defs.F90.

A more general solution looks something like

  • Encapsulating gas, cloud, and aerosol optics -- both types and their load routines -- in a single scheme-specific module. This module probably lives with the scheme (i.e. in rrtmgp/) rather than in the tests directory.
  • Converting the examples and any remaining tests to use the encapsulated optics
  • Possibly a reorganization? tests/check_variants is used to assess accuracy with a) an alternative spectral resolution, if provided, and b) a variety of LW solver options. Does this belong somewhere else?

Footnotes

  1. Requires running make check with an appropriately-configured Python environment. 2

@RobertPincus
Copy link
Member Author

After some thinking... maybe there's a rrtmgp-frontend/testing_utils.F90 that extends tests/mo_gas_optics_defs_rrtmgp.F90 to include both cloud and aerosol optics and incorporates the netCDF reading code? Maybe it's testing-utils/mo_optics_defs.F90?

We might also take a moment to remove unused codes, e.g. examples/mo_garand_atmos_io.F90 and tests/intel_codecov.sh

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant