...
We need to retrieve three types of files efficiently for the two reanalyses with experiment id = 21 and experiment id = 22. These are all class=ea. The three "streams" are oper, moda and mfb:
- Stream: Atmospheric daily analyses (stream=oper, type=an)
- Stream: Monthly means of Daily Means (stream=moda, type=an)
- Stream: Observation departures for the data used in the reanalyses (stream=oper, type=mfb)
We provide an example for each stream below.
Retrieval of daily "stream=oper, type=an" files
The availability of the oper files for experiment = 21 is given here, and the availability of experiment = 22 is here. Please note that these pages also enable users to check the download costs for the retrievals.
...
Code Block | ||
---|---|---|
| ||
#!/usr/bin/env python import calendar from ecmwfapi import ECMWFDataServer server = ECMWFDataServer() def retrieve_rom_saf(): """ A function to demonstrate how to iterate efficiently over several years and months etc for a particular rom_saf request. Change the variables below to adapt the iteration to your needs. You can use the variable 'target' to organise the requested data in files as you wish. In the example below the data are organised in files per month. (eg "rom_saf_21_daily_201510.nc") """ yearStart = 2014 yearEnd = 2015 monthStart = 1 monthEnd = 12 for year in list(range(yearStart, yearEnd + 1)): for month in list(range(monthStart, monthEnd + 1)): startDate = '%04d%02d%02d' % (year, month, 1) numberOfDays = calendar.monthrange(year, month)[1] lastDate = '%04d%02d%02d' % (year, month, numberOfDays) target = "rom_saf_21_daily_%04d%02d.nc" % (year, month) # or name rom_saf_22_ ... requestDates = (startDate + "/TO/" + lastDate) rom_saf_request(requestDates, target) def rom_saf_request(requestDates, target): """ An ROM SAF request for analysis pressure level data. Change the keywords below to adapt it to your needs. (eg to add or to remove levels, parameters, times etc) Request cost per month is 3472 fields, ~200 Mbytes """ server.retrieve({ "class": "ea", # do not change "dataset": "rom_saf_21", # or "rom_saf_22" "expver": "21", # or "22" "stream": "oper", # do not change "type": "an", # do not change, only the analysis is available "date": requestDates, # dates, set automatically from above "levtype": "pl", # pressure level data (versus surface, sfc, and model level, ml) "levelist": "100/500/700/750/850/925/1000", # levels, required only with levtype:pl and levtype:ml "param": "129.128/130.128", # Geopotential height, Temperature (T), see http://apps.ecmwf.int/codes/grib/param-db "target": target, # output file name, set automatically from above "time": "00/03/06/09/12/15/18/21", # times of analysis (with type:an), or initialization time of forecast (with type:fc) "grid": "1.5/1.5", # Optional for GRIB, required for NetCDF. The horizontal resolution in decimal degrees. If not set, the archived grid as specified in the data documentation is used. "format": "netcdf", # Optional. Output in NetCDF format. Requires that you also specify 'grid'. If not set, data is delivered in GRIB format, as archived. }) if __name__ == '__main__': retrieve_rom_saf() |
Retrieval of "stream=moda, type=an" files
The request below will retrieve all the available moda files from 200702 to 201512. This particular example is retrieving the 70 hPa zonal wind from rom_saf_22. The retrieval is grouped into decades rom_saf_moda_2000 contains the information from 200702 to 200912, and rom_saf-moda_2010 contains the information from 201001 to 201512. These are given in grib format.
...
Please note that the moda files for 200701 are not available.
Retrieval of "stream=oper, type=mfb" files
The mfb files contain information about the observations used in the reanalyses, for example the forecast and analysis departure statistics, assumed observation error statistics, etc. This data is available at 00/12 each day. The example below is for rom_saf_21, and we retrieve all the GPS-RO data for the year 2014. This retrieval produces one file per month. As above, the user could then combine these 12 files if required,e.g. cat month1 month2 > both_months.
...