-
Notifications
You must be signed in to change notification settings - Fork 15
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
test: add integration tests for stretched and lam use cases #217
base: main
Are you sure you want to change the base?
Conversation
for more information, see https://pre-commit.ci
Tagging @anaprietonem because we wanted to revisit the file naming discussed on the first integration tests PR |
for more information, see https://pre-commit.ci
marking as draft while adding the lam use case to this PR as well |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Happy with these changes!
dataset: | ||
cutout: | ||
- dataset: ${hardware.paths.data}/${hardware.files.dataset} | ||
thinning: 25 # ???-value in lam template |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is that a general value ? @JPXKQX views on this?
data: https://object-store.os-api.cci1.ecmwf.int/ml-tests/test-data/samples/anemoi-integration-tests | ||
files: | ||
dataset: regional-use-cases/cerra-rr-an-oper-0001-mars-5p5km-2017-2017-6h-v2-hmsi-testing.zarr | ||
forcing_dataset: regional-use-cases/aifs-ea-an-oper-0001-mars-o96-2017-2017-6h-v8-testing.zarr |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
For the forcing dataset, how long does this train currently takes? I believe for the global use case we were using a o48 dataset so wonder if that could make things faster
`training/tests/integration/test_training_cycle.yaml`. It furthermore | ||
applies use-case-specific modifications as detailed in | ||
`training/tests/integration/test_basic.yaml` to provide the location of | ||
`training/tests/integration/config/testing_modifications.yaml`. It |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Regarding the naming:
- the 'test_config.yaml' is the one related to the global deterministic model right? Could we more meaningful to call it
test_global.yaml
. - Related to this, in the future we would have uses cases related to probabilistic model or tests for the temporal interpolator. Any view on how to scale the naming conventions for those? Just wondering it could be good to do it already now with test_[coverage][model_task][forecaster_class]. Where coverage would be global/lam/stretched grid, model_task could be forecaster/interpolator and class would refer to single or probabilistic
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Great work both! I left some comments regarding views on scaling the naming convention and pinned Mario as he might has some views on the settings for LAM & stretched grid
Thank you for this inspiring PR. I have to minor questions, posted individually, and I'm wondering whether this test is supposed to run on a CPU? |
overrides=overrides, | ||
) # apply architecture overrides to template since they override a default | ||
use_case_modifications = OmegaConf.load(Path.cwd() / "training/tests/integration/config/test_basic.yaml") | ||
use_case_modifications = OmegaConf.load(Path.cwd() / "training/tests/integration/config/test_config.yaml") |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is Path.cwd()
relative to the working directory when executing pytest
?
temp_dir = str(tmp_path) | ||
testing_modifications.hardware.paths.output = temp_dir | ||
return testing_modifications | ||
def stretched_config(testing_modifications_with_temp_dir: OmegaConf) -> None: |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is the return type correct?
Do Not Merge
Description
Code Compatibility
Code Performance and Testing
Documentation
📚 Documentation preview 📚: https://anemoi-training--217.org.readthedocs.build/en/217/
📚 Documentation preview 📚: https://anemoi-graphs--217.org.readthedocs.build/en/217/
📚 Documentation preview 📚: https://anemoi-models--217.org.readthedocs.build/en/217/