Graph Machine Learning
AnemoI
English
File size: 11,012 Bytes
ae26443
 
4d3cfbf
 
 
ae26443
 
4d3cfbf
ae26443
 
 
4d3cfbf
 
 
b6d9f46
 
4d3cfbf
 
3dd23b4
ae26443
 
 
 
 
 
 
29e5c90
 
b6d9f46
da8a0ff
 
 
 
b6d9f46
 
 
 
 
29e5c90
 
 
ae26443
55d280a
 
 
 
e670aa6
ae26443
 
 
e670aa6
55d280a
3dd23b4
664461c
ae26443
 
 
3dd23b4
 
 
 
 
 
 
ae26443
88fedcc
3dd23b4
88fedcc
 
 
 
21e50b9
88fedcc
21e50b9
 
88fedcc
da8a0ff
3dd23b4
fec0ad0
88fedcc
21e50b9
da8a0ff
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
ae26443
 
 
 
 
 
 
18e6b7d
 
 
 
 
 
 
 
 
 
55d280a
ae26443
e670aa6
 
 
ae26443
 
 
 
e670aa6
55d280a
 
e670aa6
55d280a
 
e670aa6
55d280a
 
ae26443
 
 
 
e670aa6
 
 
 
 
 
 
 
 
ae26443
e670aa6
ae26443
 
 
e670aa6
 
6b6331d
 
ae26443
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
6b6331d
ae26443
6b6331d
ae26443
6b6331d
ae26443
675d4fb
 
ae26443
6b6331d
ae26443
7a61fa4
 
 
 
 
 
ae26443
664461c
ae26443
664461c
 
 
 
 
 
 
ae26443
 
 
 
 
 
664461c
ae26443
 
 
664461c
ae26443
664461c
ae26443
 
4ec6fbf
ae26443
4ec6fbf
ae26443
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
---
license: cc-by-sa-4.0
metrics:
- mse
pipeline_tag: graph-ml
---

# AIFS Single - v0.2.1

<!-- Provide a quick summary of what the model is/does. -->

Here, we introduce the **Artificial Intelligence Forecasting System (AIFS)**, a data driven forecast
model developed by the European Centre for Medium-Range Weather Forecasts (ECMWF). 

![AIFS 10 days forecast](aifs_10days.gif)

We show that AIFS produces highly skilled forecasts for upper-air variables, surface weather parameters and
tropical cyclone tracks. AIFS is run four times daily alongside ECMWF’s physics-based NWP model and forecasts
are available to the public under ECMWF’s open data policy. (https://www.ecmwf.int/en/forecasts/datasets/open-data)

## Model Details

### Model Description

<!-- Provide a longer summary of what this model is. -->

AIFS is based on a graph neural network (GNN) encoder and decoder, and a sliding window transformer processor, 
and is trained on ECMWF’s ERA5 re-analysis and ECMWF’s operational numerical weather prediction (NWP) analyses. 

<div style="display: flex; justify-content: center;">
  <img src="aifs_diagram.png" alt="High-level AIFS diagram" style="width: 50%;"/>
</div>

<div style="display: flex;">
  <img src="encoder_graph.jpeg" alt="Encoder graph" style="width: 50%;"/>
  <img src="decoder_graph.jpeg" alt="Decoder graph" style="width: 50%;"/>
</div>

It has a flexible and modular design and supports several levels of parallelism to enable training on
high resolution input data. AIFS forecast skill is assessed by comparing its forecasts to NWP analyses
and direct observational data. 

- **Developed by:** ECMWF
- **Model type:** Encoder-processor-decoder model
- **License:** CC BY-SA 4.0

### Model Sources

<!-- Provide the basic links for the model. -->


- **Repository:** [Anemoi](https://anemoi-docs.readthedocs.io/en/latest/index.html)
  Anemoi is an open-source framework for creating machine learning (ML) weather forecasting systems, which ECMWF and a range of national meteorological services across Europe have co-developed.
- **Paper:** https://arxiv.org/pdf/2406.01465

## How to Get Started with the Model

To be able to run AIFS to generate a new forecast, you can use ai-models https://github.com/ecmwf-lab/ai-models.
`ai-models` command can be used to run different models, since in this case we are looking at using AIFS we need to speficy
`anemoi` as `model-name` and then pass the path to the checkpoint (`aifs_single_v0.2.1.ckpt`) and the initial conditions. 
You can find an example of a set of initial conditions in the GRIB file `example_20241107_12_n320.grib`.

Use the code below to get started with the model. 


```
# 1st create the conda environment
export CONDA_ENV=aifs-env
conda create -n ${CONDA_ENV} python=3.10
conda activate ${CONDA_ENV}

pip install torch=2.4
pip install anemoi-inference[plugin] anemoi-models==0.2
pip install ninja
pip install flash-attn --no-build-isolation

# 2nd Run ai-models to generate weather forecast

ai-models anemoi --checkpoint aifs_single_v0.2.1.ckpt --file example_20241107_12_n320.grib
```

**Note** we train AIFS using `flash_attention` (https://github.com/Dao-AILab/flash-attention)
There are currently some issues when trying to install flash attention with the latest PyTorch version 2.5 and CUDA 12.4 (https://github.com/Dao-AILab/flash-attention/issues/1330)
For that reason we recommen you install PyTorch 2.4

After running the `ai-models` command the output of the forecast should be written into `anemoi.grib` 
Below you can find an example to read that file and load it as numpy array or xarray. 

```

import earthkit.data as ekd

source_filename='anemoi.grib'
aifs_forecast = ekd.from_source('file',source_filename)

# to load it as a numpy array
aifs_forecast.to_numpy()

# to load it as a xarray array
aifs_forecast.to_xarray()

```

## Training Details

### Training Data

<!-- This should link to a Dataset Card, perhaps with a short stub of information on what the training data is all about as well as documentation related to data pre-processing or additional filtering. -->

AIFS is trained to produce 6-hour forecasts. It receives as input a representation of the atmospheric states
at \\(t_{−6h}\\), \\(t_{0}\\), and then forecasts the state at time \\(t_{+6h}\\). 

The full list of input and output fields is shown below:

| Field                                                                                                                                                       | Level type                                                                   | Input/Output |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|--------------|
| Geopotential, horizontal and vertical wind components, specific humidity, temperature                                                                       | Pressure level: 50,100, 150, 200, 250,300, 400, 500, 600,700, 850, 925, 1000 | Both         |
| Surface pressure, mean sea-level pressure, skin temperature, 2 m temperature, 2 m dewpoint temperature, 10 m horizontal wind components, total column water | Surface                                                                      | Both         |
| Total precipitation, convective precipitation                                                                                                               | Surface                                                                      | Output       |
| Land-sea mask, orography, standard deviation of sub-grid orography, slope of sub-scale orography, insolation, latitude/longitude, time of day/day of year   | Surface                                                                      | Input        |

Input and output states are normalised to unit variance and zero mean for each level. Some of
the forcing variables, like orography, are min-max normalised.

### Training Procedure

<!-- This relates heavily to the Technical Specifications. Content here should link to that section when it is relevant to the training procedure. -->

- **Pre-training**: It was performed on ERA5 for the years 1979 to 2020 with a cosine learning rate (LR) schedule and a total
of 260,000 steps. The LR is increased from 0 to \\(10^{-4}\\) during the first 1000 steps, then it is annealed to a minimum
of \\(3 × 10^{-7}\\).
- **Fine-tuning I**: The pre-training is then followed by rollout on ERA5 for the years 1979 to 2018, this time with a LR
of \\(6 × 10^{-7}\\). As in [Lam et al. [2023]](https://doi.org/10.48550/arXiv.2212.12794) we increase the
rollout every 1000 training steps up to a maximum of 72 h (12 auto-regressive steps).
- **Fine-tuning II**: Finally, to further improve forecast performance, we fine-tune the model on operational real-time IFS NWP
analyses. This is done via another round of rollout training, this time using IFS operational analysis data
from 2019 and 2020


#### Training Hyperparameters

- **Optimizer:** We use *AdamW* (Loshchilov and Hutter [2019]) with the \\(β\\)-coefficients set to 0.9 and 0.95.

- **Loss function:** The loss function is an area-weighted mean squared error (MSE) between the target atmospheric state
and prediction.

- **Loss scaling:** A loss scaling is applied for each output variable. The scaling was chosen empirically such that
all prognostic variables have roughly equal contributions to the loss, with the exception of the vertical velocities,
for which the weight was reduced. The loss weights also decrease linearly with height, which means that levels in 
the upper atmosphere (e.g., 50 hPa) contribute relatively little to the total loss value.

#### Speeds, Sizes, Times

<!-- This section provides information about throughput, start/end time, checkpoint size if relevant, etc. -->

Data parallelism is used for training, with a batch size of 16. One model instance is split across four 40GB A100
GPUs within one node. Training is done using mixed precision (Micikevicius et al. [2018]), and the entire process
takes about one week, with 64 GPUs in total. The checkpoint size is 1.19 GB and it does not include the optimizer 
state.

## Evaluation

<!-- This section describes the evaluation protocols and provides the results. -->

### Testing Data, Factors & Metrics

#### Testing Data

<!-- This should link to a Dataset Card if possible. -->

{{ testing_data | default("[More Information Needed]", true)}}

#### Factors

<!-- These are the things the evaluation is disaggregating by, e.g., subpopulations or domains. -->

{{ testing_factors | default("[More Information Needed]", true)}}

#### Metrics

<!-- These are the evaluation metrics being used, ideally with a description of why. -->

{{ testing_metrics | default("[More Information Needed]", true)}}

### Results

{{ results | default("[More Information Needed]", true)}}

#### Summary

{{ results_summary | default("", true) }}

## Model Examination [optional]

<!-- Relevant interpretability work for the model goes here -->

{{ model_examination | default("[More Information Needed]", true)}}

## Technical Specifications

### Hardware

<!--  {{ hardware_requirements | default("[More Information Needed]", true)}} -->

We acknowledge PRACE for awarding us access to Leonardo, CINECA, Italy. In particular, this version of the AIFS has been trained 
on 64 A100 GPUs (40GB).

### Software

The model was developed and trained using the [AnemoI framework](https://anemoi-docs.readthedocs.io/en/latest/index.html).
AnemoI is a framework for developing machine learning weather forecasting models. It comprises of components or packages
for preparing training datasets, conducting ML model training and a registry for datasets and trained models. AnemoI
provides tools for operational inference, including interfacing to verification software. As a framework it seeks to
handle many of the complexities that meteorological organisations will share, allowing them to easily train models from
existing recipes but with their own data.

## Citation

<!-- If there is a paper or blog post introducing the model, the APA and Bibtex information for that should go in this section. -->

If you use this model in your work, please cite it as follows:

**BibTeX:**

```
@article{lang2024aifs,
  title={AIFS-ECMWF's data-driven forecasting system},
  author={Lang, Simon and Alexe, Mihai and Chantry, Matthew and Dramsch, Jesper and Pinault, Florian and Raoult, Baudouin and Clare, Mariana CA and Lessig, Christian and Maier-Gerber, Michael and Magnusson, Linus and others},
  journal={arXiv preprint arXiv:2406.01465},
  year={2024}
}
```

**APA:**

```
Lang, S., Alexe, M., Chantry, M., Dramsch, J., Pinault, F., Raoult, B., ... & Rabier, F. (2024). AIFS-ECMWF's data-driven forecasting system. arXiv preprint arXiv:2406.01465.
```


## More Information

[More Information Needed](https://arxiv.org/pdf/2406.01465)