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

generate_levels_constraint takes any iterable coordinate, should we generalise this constraint? #1004

Open
daflack opened this issue Dec 16, 2024 · 1 comment
Assignees
Labels
question Further information is requested

Comments

@daflack
Copy link
Contributor

daflack commented Dec 16, 2024

The generate_levels_constraint works with any iterable coordinate, i.e. it takes model/pressure level and stratifies based on those. However, it also has the ability to stratify by ensemble member as realization is an iterable coordinate.

To close #132 the documentation was updated for generate_levels_constraint to show this. I took this option as I thought it was more sensible to document it than create duplicate code. However, this did raise a question: for ease of usability should the generate_levels_operator be renamed to something generic and the levels variable be renamed as well, or potentially just one of the two?

@daflack daflack added the question Further information is requested label Dec 16, 2024
@jfrost-mo
Copy link
Member

I slightly shy away from totally generic functions as they can be hard to understand how to use them.

In this case I'd be tempted to add a specific stratify_ensemble_member_operator_name operator, which can itself just use the generate levels constraint under the hood. That way the interface is clear (and we can automatically use realization), while the code isn't actually duplicated.

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

No branches or pull requests

5 participants