-
Notifications
You must be signed in to change notification settings - Fork 3
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
Comments
@RobertPincus could pull one time-step from aqua planet (a round planet without elevation) |
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. |
@sehnem I can do that. Do you mean to extend the testing suite? |
@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. |
@sehnem I have such examples in |
@RobertPincus I think that this is what I need, will use this as reference and implement it in python. |
@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. |
@sehnem In the Fortran 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. |
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) |
ERA5 reanalysis would be compelling. The issue is that it lacks some fields so we'd need to interpolate. |
@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 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? |
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)The text was updated successfully, but these errors were encountered: