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 more usage examples #28

Open
tcmetzger opened this issue Apr 1, 2024 · 11 comments
Open

Add more usage examples #28

tcmetzger opened this issue Apr 1, 2024 · 11 comments
Assignees
Labels
good first issue Good for newcomers
Milestone

Comments

@tcmetzger
Copy link
Collaborator

tcmetzger commented Apr 1, 2024

To make it easier to start using this library and illustrate its various use cases, we want to add usage examples highlighting the additional cloud and aerosol- related functionalities (Jupyter notebooks in the repository’s /examples folder)

@tcmetzger tcmetzger added the good first issue Good for newcomers label Apr 1, 2024
@tcmetzger tcmetzger added this to the Future milestone Apr 9, 2024
@tcmetzger tcmetzger modified the milestones: Future, Phase 2 Oct 11, 2024
@tcmetzger
Copy link
Collaborator Author

@RobertPincus could pull one time-step from aqua planet (a round planet without elevation)

@sehnem
Copy link
Collaborator

sehnem commented Nov 15, 2024

We need to add examples that use different paths on processing the data. Currently just two functions of RTE are used, we should implement all the functions and use them.

@RobertPincus
Copy link
Member

@sehnem I can do that. Do you mean to extend the testing suite?

@sehnem
Copy link
Collaborator

sehnem commented Nov 15, 2024

@RobertPincus it would be good to have the same examples in fortran too, so we could use the same output data to test both and make sure it is consistent, it can be just examples, in python I use the examples as integration tests.

@RobertPincus
Copy link
Member

@sehnem I have such examples in tests/test_variants; I can think about how to incorporate them.

@sehnem
Copy link
Collaborator

sehnem commented Nov 15, 2024

@RobertPincus I think that this is what I need, will use this as reference and implement it in python.

@RobertPincus
Copy link
Member

@sehnem The most widely-used variant that's different from the clear sky is longwave clouds for which we use two-stream optical properties. For this we will need the cloud-optics in Python, as well as the ability to add two sets of optical properties together. The latter I can help with. The Python cloud optics is #53 and should be ready for Makepath to implement.

@RobertPincus
Copy link
Member

@sehnem In the Fortran repo examples/all-sky would be another good example. It uses idealized profiles of temperature, humidity, and ozone; adds a bunch of other gases as scalars, and adds cloud to 2/3 of the columns. The clouds employ the 2-stream/LW logic. There are reference answers in the data repo.

The all-sky example might also be useful because it's very flexible - users can pick the number of columns and the vertical discretization, and we sometimes use it to assess timing.

@tcmetzger
Copy link
Collaborator Author

From the 12/1/2024 call: We want to find a well-known, standardized example dataset. We then want to show how pyRTE can be used to process this data efficiently (using dask #54)

@RobertPincus
Copy link
Member

RobertPincus commented Dec 18, 2024

ERA5 reanalysis would be compelling. The issue is that it lacks some fields so we'd need to interpolate.

@sehnem
Copy link
Collaborator

sehnem commented Jan 14, 2025

@RobertPincus and @makepath-alex, I'm trying to use the bindings for the cloud functions but I am getting strange results, and it appears there might be an issue in the rrtmgp_compute_cld_from_table function. Please correct me if I'm wrong, as my experience with bindings is limited.

In the C header, nsteps is the fourth argument:

void rrtmgp_compute_cld_from_table(
        const int& ncol, int& nlay, int& nbnd, int& nsteps,
        const Bool*  mask, // (ncol,nlay)
        const Float* lwp,  // (ncol,nlay)
        const Float* re,   // (ncol,nlay)
        const Float& step_size,
        const Float& offset,
        const Float* tau_table, // (nsteps, nbnd)
        const Float* ssa_table, // (nsteps, nbnd)
        const Float* asy_table, // (nsteps, nbnd)
        Float* tau,     // (ncol,nlay,nbnd)
        Float* taussa,  // (ncol,nlay,nbnd)
        Float* taussag  // (ncol,nlay,nbnd)
    );

However, in the Fortran definition, it's the seventh:

subroutine compute_cld_from_table(ncol, nlay, nbnd, mask, lwp, re, &
                                      nsteps, step_size, offset,       &
                                      tau_table, ssa_table, asy_table, &
                                      tau, taussa, taussag) bind(C, name="rrtmgp_compute_cld_from_table")
      use mo_rte_kind, only : wp, wl
      integer,                                intent(in) :: ncol, nlay, nbnd, nsteps
      logical(wl), dimension(ncol,nlay),      intent(in) :: mask
      real(wp),    dimension(ncol,nlay),      intent(in) :: lwp, re
      real(wp),                               intent(in) :: step_size, offset
      real(wp),    dimension(nsteps,   nbnd), intent(in) :: tau_table, ssa_table, asy_table
      real(wp),    dimension(ncol,nlay,nbnd)             :: tau, taussa, taussag
    end subroutine compute_cld_from_table

Shouldn't the arguments be in the same order in both definitions, or it will not make any difference?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
good first issue Good for newcomers
Projects
Status: In progress
Development

No branches or pull requests

3 participants