Table of Contents
What is the objective of this page?
Info |
---|
To help users to improve S2S CMA MARS requests performance via the WebAPI. A good understanding of the MARS efficiency issues is essential especially for users that are interested in downloading large amounts of data. |
How is the S2S reforecast data organised in MARS?
Info |
---|
In general it is organised, as a huge tree, with the indentation below, showing different levels down that tree:
|
What would be the natural way to group requests?
Info |
---|
The idea is to request as much data as possible from the same tape file. The natural way to group requests would be: Note the following:
|
Best practise to iterate over all hindcastDates of several hindcastYears for CMA
Info |
---|
At this point you may wish to check CMA availability and to view a CMA request |
Info |
---|
for hindcastYear in hindcastYears |
Web-API examples:
A CMA reforecast request for
...
all the available hindcastDates
Info |
---|
Please note:
|
Code Block | ||
---|---|---|
| ||
#!/usr/bin/env python import calendar from ecmwfapi import ECMWFDataServer server = ECMWFDataServer() origin = "babj" modelVersionDate = "2014-05-01" def # This is the first model version for CMA (babj) hindcastDate = "2014-04-01"retrieve_cma_reforecast(): """ A #function Theto selecteddemonstrate hindcasthow date serverto = ECMWFDataServer() server.retrieve({ "class": "s2", iterate efficiently over all hindcastYears, hindcastMonths etc "dataset": "s2s", "date": modelVersionDate, for a "expver": "prod", particular cma_reforecast_request. "hdate": hindcastDate, "levtype": "sfc", Change the "origin": "babj", "param": "165/166", "step": "24/to/1440/by/24",variables below to adapt the iteration to your needs "stream": "enfh", "target": "data.pf.sfc",hindcastYearStart = 1994 "time": "00", hindcastYearEnd = 2014 hindcastMonthStart "number":= "1/2/3", "type": "pf", }) |
A CMA reforecast request for several hindcastDates
Info | ||||
---|---|---|---|---|
Code Block | ||||
| ||||
#!/usr/bin/env python from ecmwfapi import ECMWFDataServer server = ECMWFDataServer() def retrieve_data(hindcastDate,modelVersionDate,centre hindcastMonthEnd = 12 for hindcastYear in list(range(hindcastYearStart, hindcastYearEnd + 1)): target = "target_s2s_%s_%s.grb" % centre % hindcastDate for hindcastMonth in list(range(hindcastMonthStart, hindcastMonthEnd + 1)): server.retrieve({ numberOfDays "class": "s2",= calendar.monthrange(hindcastYear, hindcastMonth)[1] "dataset": "s2s", for hindcastDay "date": modelVersionDate,in list(range(numberOfDays)): "expver": "prod", "hdate": hindcastDate, = '%04d%02d%02d' % ( "levtype": "sfc", "origin": centre, "param": "165", "step": "0", hindcastYear, hindcastMonth, hindcastDay + 1) "stream": "enfh", target = "target": target,%s%s.grb" % (origin, hindcastDate) "time": "00", "type": "cf", } cma_reforecast_request(hindcastDate, target) for hindcastYear in ["2012", "2013"]def cma_reforecast_request(hindcastDate, target): for hindcastMonth in ["08", "09"]: for hindcastDay in ["01" "02" ]:""" A CMA reforecast hindcastDate = hindcastYear+hindcastMonth+hindcastDay request. Change the keywords below to adapt it to your needs. retrieve_data(hindcastDate,"2014-05-01","babj") | ||||
Code Block | ||||
| ||||
for hindcastYear in ["2012", "2013"]:" server.retrieve({ for hindcastMonth in ["08class",: "09s2"]:, if hindcastMonth in ["01dataset",: "03s2s", "05", "07", "08", "10", "12"]: hindcastDateEnd = "31date": modelVersionDate, if hindcastMonth in [ "04","expver": "06prod", "09", "11"]: hindcastDateEnd = "30" "hdate": hindcastDate, for hindcastDay in ["01levtype" ... hindcastDateEnd ]:: "sfc", "origin": origin, hindcastDate = hindcastYear+hindcastMonth+hindcastDay "param": "165/166", retrieve_data(hindcastDate,"2014-05-01","babj") | ||||
Code Block | ||||
| ||||
for hindcastYear in ["2012", "2013"]:"step": "24/to/1440/by/24", "stream": "enfh", for hindcastMonth in ["08", "09target"]: target, for hindcastDay in ["01" "06" "11" "16" "21" "26"]:"time": "00", "number": "1/2/3", "type": "pf", hindcastDate = hindcastYear+hindcastMonth+hindcastDay }) if __name__ == '__main__': retrieve_cma_data(hindcastDate,"2014-01-01","ammc") |
...
reforecast() |
Useful links
Info |
---|
...