GPTCast: a weather language model for precipitation nowcasting
Abstract. This work introduces GPTCast, a generative deep-learning method for ensemble nowcast of radar-based precipitation, inspired by advancements in large language models (LLMs). We employ a GPT model as a forecaster to learn spatiotemporal precipitation dynamics using tokenized radar images. The tokenizer is based on a Quantized Variational Autoencoder featuring a novel reconstruction loss tailored for the skewed distribution of precipitation that promotes faithful reconstruction of high rainfall rates. The approach produces realistic ensemble forecasts and provides probabilistic outputs with accurate uncertainty estimation. The model is trained without resorting to randomness, all variability is learned solely from the data and exposed by model at inference for ensemble generation. We train and test GPTCast using a 6-year radar dataset over the Emilia-Romagna region in Northern Italy, showing superior results compared to state-of-the-art ensemble extrapolation methods.
Status: open (extended)
-
CEC1: 'Comment on egusphere-2024-3002', Juan Antonio Añel, 30 Oct 2024
reply
Dear authors,
Unfortunately, after checking your manuscript, it has come to our attention that it does not comply with our "Code and Data Policy".
https://www.geoscientific-model-development.net/policies/code_and_data_policy.htmlYou have archived part of your code on GitHub. However, GitHub is not a suitable repository for scientific publication. GitHub itself instructs authors to use other long-term archival and publishing alternatives, such as Zenodo. Therefore, the current situation with your manuscript is irregular. Please, move this GitHub posted code to one of the appropriate repositories and reply to this comment with the relevant information for it (link and a permanent identifier for it (e.g. DOI)) as soon as possible, as we can not accept manuscripts in Discussions that do not comply with our policy.
Please, note that if you do not fix this problem, we could have to reject your manuscript for publication in our journal.
Also, you must include the modified 'Code and Data Availability' section in a potentially reviewed manuscript, the new link and DOI of the code.
Juan A. Añel
Geosci. Model Dev. Executive EditorCitation: https://doi.org/10.5194/egusphere-2024-3002-CEC1 -
EC1: 'Reply on CEC1', David Topping, 30 Oct 2024
reply
Dear Juan
The data and code assets are archived on zenodo, as listed in the paper assets tab. An interactive notebook, however, is hosted on Github so I agree this should be included as part of the discussion phase and was intended to do so. Howver the Copernicus email instructions [6/10/24] state that 'Please note, you will not be able to ask for revisions since the preprint has already been posted ', which is rather confusing. Given the tone of your email, could you please clarify at what stage the authors should do this?
Thanks
DaveCitation: https://doi.org/10.5194/egusphere-2024-3002-EC1 -
CEC2: 'Reply on EC1', Juan Antonio Añel, 31 Oct 2024
reply
Dear Dave, Dear authors,
The automatic email from the system means that it is not going to be possible to make changes to the current version in Discussions after the Topical Editor has agreed on publishing it there. However, it is possible to ask for revisions, like in any part of the review process.
Therefore, comments can be made here replying to my request, and new information posted, like the new acceptable repository needed that I request. Actually, this should be done as soon as possible, as any manuscript in Discussions that does not comply with the policy of the journal is a potential risk of wasting time from reviewers and editors. For example, if editors and reviewers perform all the review process and authors finally do not comply with the policy. This could seem unfortunate, but happens sometimes.
Finally, if reviewers recommend a new round of reviews or publication, and you decide to invite a new version of the manuscript or accept this one, during the process, in a new submitted version of the manuscript, the authors can include the information that they posted here in Discussions replying to my comment.
I hope this clarify the situation.
Juan A. Añel
Geosci. Model Dev. Executive Editor
Citation: https://doi.org/10.5194/egusphere-2024-3002-CEC2 -
AC1: 'Reply on CEC2', Gabriele Franch, 01 Nov 2024
reply
Dear Juan, Dear Dave,
The code asset we submitted on Zenodo contains the full archived copy of the Github repository, including both the code and the interactive notebooks: https://zenodo.org/records/13832526
We added the Github link as a convenience source for the interactive computing environment. since it does not require to extract the archive and allows to visualize the notebooks via web, but we understand that this may be a source of confusion for the reviewers since we are listing two different sources for the same asset.
We apologize for the confusion that this may have caused. Please disregard the github link and refer only to the asset archived on Zenodo as a reference for both the code and the interactive notebooks.
We hope this clarifies the situation.
Gabriele Franch
Citation: https://doi.org/10.5194/egusphere-2024-3002-AC1
-
AC1: 'Reply on CEC2', Gabriele Franch, 01 Nov 2024
reply
-
CEC2: 'Reply on EC1', Juan Antonio Añel, 31 Oct 2024
reply
-
EC1: 'Reply on CEC1', David Topping, 30 Oct 2024
reply
-
RC1: 'Review of GPTCast - LLMs meet nowcasting', Anonymous Referee #1, 26 Dec 2024
reply
Review of GPTCast
The authors present a nowcasting framework which makes use of principles from large language models (LLMs) to generate an ensemble of radar-based precipitation nowcasts for lead times up to two hours. To this end, the radar rainfall images are split up into patches which the tokenizer learns to encode using a finite, optimal “dictionary” of possible tokens. The whole radar image can thus be compressed using this discretized representation. An optimized Magnitude Weighted Absolute Error (MWAE) loss function is used for training the tokenizer, to give a higher importance to extremes.
In the next step, the sequences of radar patch tokens, similarly to words for LLMs, are used as input to predict the next tokens for each patch location. Not just the temporal sequence but also nearby tokens in space, resulting in a 3D context grid, are used as input to predict the next tokens. The authors claim that the obtained precipitation forecasts are both realistic and reliable in a probabilistic sense. They claim that the model is “fully deterministic” and does not require random inputs (see my later comment about this statement).
The dataset used is the 5-minute ARPAE data from two radars in Central Italy. The data is filtered to include only rainy sequences, and from these sequences some extreme cases are selected for the tokenizer test dataset. The rest is randomly divided into training and validation set. From the tokenizer test dataset, a subset is selected to test the forecaster; I have some reservations about this choice which I will detail below. The proposed methods are shown to improve upon a state-of-the-art non-machine-learning based nowcasting method (LINDA).
The authors present a novel and highly original approach to nowcasting based on LLMs, which could cause rapid progress in nowcasting by piggybacking on the fast-developing field of LLMs. For now, however, a big down side remains the high computational cost of both training and inference. The paper is well-written, and the methodology is supported by overall clear figures, although the description of the loss functions and certain parameter choices could use a more in-depth discussion, and some methodological choices could be improved as described below. I recommend publication if the unclear points below are clarified, and the remaining issues are addressed or the choices clearly motivated in the manuscript.
General comments and questions
“The model is trained without resorting to randomness” - it’s not clear to me what the authors mean by this claim. Is there no randomness used at all (e.g. no stochasticity in the training process / optimization or the batch selection)? Does it also mean that a given sequence of rainfall images will always deterministically produce the same forecast? Either way, why would this be desirable? Further, they contrast this to other methods which “require random input” - it would be helpful if they are more precise about what they mean exactly by this random input. I suppose it refers to the noise fields used in the training of e.g. diffusion models, but the author’s meaning could be made more explicit.
Some details such as the units of the input data could be clarified more. In that respect, the authors do not mention the error sources affecting the weather radar reflectivity images. Nowcasting systems often use multimodal quantitative precipitation estimates (QPE) (for which radar is of course the main source of information in the areas where it is available, but clutter filtering and rain gauge corrections are often applied). I would also be curious to know how the authors handle the large number of dry patches.
The different terms in the VQGAN loss function could be explained in more detail, for example the LPIPS is not mentioned anywhere in the text. The choice of the different parameters could be better motivated (e.g. why the latent space size of 8; was this based on experience/ literature or were other values tested with worse results?)
If I understand correctly, the output of the model is the distribution for a single token at the center of the spatial window (this seems to be the case based on Fig. 2). The spatial domain can be extended by applying a sliding window approach. Please clarify how the resulting target token distributions are combined and how spatial consistency is obtained. Also, what happens at the edge of the domain?
The authors claim that the dual-stage architecture enables realistic ensemble generation and accurate uncertainty estimation, but it is not clear to me why this would not be the case in a different scenario, for example if the two stages were trained simultaneously – this claim could be further clarified or supported with evidence.
How does the spatial tokenizer deal with local extremes (e.g. a 100-year return level)? How can highly efficient codebook usage (100%) be compatible with such rare extreme values?
The sigmoid function in the MWAE indeed gives more weight to high rain rates, but at the same time the saturation of the sigmoid will make that the factor |sigma(x_i)-sigma(y_i)| will be very small even if x and y represent large differences in very high rain rates. Isn’t this problematic, given that the impact on the ground between a 100- or a 200-year return level event is quite substantial?
The authors discard the non-precipitating series, which represents 71.5% of the data. If the model is used for operational nowcasting, it will also receive dry radar images. How is this dealt with?
The authors apply random rotations in the training phase. How do the authors avoid that the model learns patterns that are unphysical in the sense that the dominant wind direction, orographic enhancement of precipitation etc. will not be learned correctly due to these transformations? Is some context (e.g. topography) provided?
Are the scores with units in table 3 calculated for the reflectivity values in dBZ or for the rain rates? Note that it is easier to interpret RMSE than MSE. It would help to somehow indicate which model score is the best one, e.g. by underlining it.
Figure 6: Just to be sure, does the box really contain 50% of the points or do the vertical and horizontal sides of the box contain 50% of the points, respectively?
Strictly speaking, there’s a methodological flaw in the selection of the model (either with MAE or MWAE) and the reporting of its performance for forecasting. The authors choose a tokenizer variant based on its performance on the test set, and then go on to evaluate the performance of the resulting nowcasting scheme on a subset of the same test set. The resulting model can very well be the best one, but its score on the FTS (which is a subset of the TTS period) is not representative of the performance for new, truly unseen data. I would like to see the performance of an independent (e.g. more recent) event that was not part of the training / validation / test datasets.
Finally, out of curiosity, I would like to know how hard it would be to retrain the model on a different region. Does everything need to be retrained from scratch, or can one start from a pretrained model (or only the VQGAN for example)? This would significantly reduce the high computational cost associated with these kinds of models.
Minor and typographical remarks
· Please explain all acronyms upon first usage (e.g. GPT in line 2 of the abstract).
· Something went wrong in the placement of the parentheses of the references. E.g. the first reference “ [...] early warning systemsGöber et al. (2023).” should probably have been “ [...] early warning systems (Göber et al. 2023).
p.1
· Line 1 of the abstract: “method for ensemble nowcast” -> method for ensemble nowcasting
· “all variability is learned solely from the data and exposed by model at inference for ensemble generation.” This part is also a bit unclear (and “the” is missing).
p. 2:
· preserving the precipitation field’s structure -> do you mean “structural characteristics”? Because the mentioned methods don’t necessarily preserve the structure.
· [...] uncertainty that manifests _itself_ as... /or/ that is manifested as
· [...] including _the_ medium range weather forecasting domain
p. 4:
· [...] we find _it_ useful
p. 5:
· Figure 1: explain the meaning of “stop gradient”
p. 7:
· Square km -> km^2
· 1km resolution per pixel -> a resolution of 1 km by 1 km
p. 9:
· We analyze the performances of our model -> … the performance of our models (?)
· Elsewhere: performances -> performance
p. 13:
· Tendency to underestimation -> tendency to underestimate
p. 14:
· Not clear what the authors mean by “The model can be declined […]”
Citation: https://doi.org/10.5194/egusphere-2024-3002-RC1
Data sets
Dataset for "GPTCast: a weather language model for precipitation nowcasting" Gabriele Franch, Elena Tomasi, Chaira Cardinali, Virginia Poli, Pier Paolo Alberoni, and Marco Cristoforetti https://doi.org/10.5281/zenodo.13692016
Model code and software
Code for "GPTCast: a weather language model for precipitation nowcasting" Gabriele Franch, Elena Tomasi, and Marco Cristoforetti https://doi.org/10.5281/zenodo.13832526
Interactive computing environment
Jupyter Notebooks for "GPTCast: a weather language model for precipitation nowcasting" Gabriele Franch, Elena Tomasi, and Marco Cristoforetti https://github.com/DSIP-FBK/GPTCast/tree/main/notebooks
Viewed
Since the preprint corresponding to this journal article was posted outside of Copernicus Publications, the preprint-related metrics are limited to HTML views.
HTML | XML | Total | BibTeX | EndNote | |
---|---|---|---|---|---|
181 | 0 | 0 | 181 | 0 | 0 |
- HTML: 181
- PDF: 0
- XML: 0
- Total: 181
- BibTeX: 0
- EndNote: 0
Viewed (geographical distribution)
Since the preprint corresponding to this journal article was posted outside of Copernicus Publications, the preprint-related metrics are limited to HTML views.
Country | # | Views | % |
---|
Total: | 0 |
HTML: | 0 |
PDF: | 0 |
XML: | 0 |
- 1