Skip to content
This repository has been archived by the owner on Dec 20, 2024. It is now read-only.

Update sanity checks for training data consistency #120

Merged
merged 15 commits into from
Dec 3, 2024

Conversation

JesperDramsch
Copy link
Member

@JesperDramsch JesperDramsch commented Nov 1, 2024

This PR implements a callback that tries to ensure that the variable in the training are in order.

The following scenarios are checked:

Model Scenarios

There are two scenarios for the model:

New Model

A fresh model will get the name_to_index from the training dataset and compare to validation and test on epoch start.

From Checkpoint

A model that is restored from a checkpoint will retrieve the name_to_index in existing data_indices and compare them to instantiated data_indices.

Error Scenarios

There are valid, warning, and error scenarios:

Valid Scenario

The name_to_index is identical

Warnings

When variables are renamed but in the same locations, a warning is issued but training will not be blocked.

Errors

Values are renamed in different locations, which will result in an error.

Values are permuted, will result in an error

Removes the Resolution Check

Currently there is a resolution check, which I was told gets in the way of training with merged datasets et al.

Upon consideration of factoring this into another Callback, I decided to get rid of the check instead, as it would be flaky at best and breaking at the worst.

@HCookie pointed out this was also flagged now in ecmwf/anemoi-core#23

src/anemoi/training/data/datamodule.py Outdated Show resolved Hide resolved
src/anemoi/training/diagnostics/callbacks/sanity.py Outdated Show resolved Hide resolved
tests/diagnostics/callbacks/test_variable_order.py Outdated Show resolved Hide resolved
@JesperDramsch JesperDramsch changed the title Check Variable Sorting during Training Update sanity checks for training data consistency Nov 5, 2024
HCookie
HCookie previously approved these changes Nov 11, 2024
HCookie
HCookie previously approved these changes Nov 14, 2024
HCookie
HCookie previously approved these changes Nov 21, 2024
HCookie
HCookie previously approved these changes Nov 21, 2024
@HCookie HCookie mentioned this pull request Nov 22, 2024
@anaprietonem anaprietonem self-requested a review December 3, 2024 12:27
CHANGELOG.md Show resolved Hide resolved
@JesperDramsch JesperDramsch merged commit bb30beb into develop Dec 3, 2024
119 checks passed
@JesperDramsch JesperDramsch deleted the pre-training-check branch December 3, 2024 12:30
@JPXKQX JPXKQX mentioned this pull request Dec 5, 2024
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants