Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.


Panel
titleColorwhite
titleBGColor#2B619E
titleIntroduction

This Service will allow authorised users to retrieve and list MARS data from outside the ECMWF facilities. Users within ECMWF Member and Co-operating States may contact their Computing Representative to obtain access to MARS. All other users may request a username and password, following these instructions.

In this page you will find the step-by-step guide to install the ECMWF Web API client and create your own MARS Requests. We strongly recommend you that you get familiar with MARS.


Info
titleInformation

For those used to the MARS system, it is worth noting that the client that you will install in your system is a Web API service interface that forwards the request to our systems and expects a single output file. It has no knowledge of internal ECMWF libraries such as MIR or ecCodes, these operations are performed in our internal servers. Therefore, not all the functionality of the full MARS client is available, like multi-target, compute, etc...

This method is only supported on UNIX systems. It requires Python.


Panel
titleColorwhite
titleBGColorblack
titleStep-by-step guide

Steps:

  1. Download mars
  2. Install ECMWF API client library
  3. Install ECMWF KEY
  4. Test installation
  5. Check availability
  6. MARS examples
  7. Brief MARS request syntax
  8. Documentation


Info

(Optional) To follow this guide, we recommend you to have a directory in your $HOME space called "mars".

Code Block
languagebash
themeConfluence
mkdir -p ~/mars/bin
mkdir -p ~/mars/lib


Anchor
downloadmars
downloadmars

Panel
titleColorwhite
titleBGColor#2B619E
titleDownload Mars

Download the mars python script: mars.

#!/usr/bin/env python
import sys
import ecmwfapi
import re
import os
import argparse

parser = argparse.ArgumentParser(description='Run MARS request.')
parser.add_argument('infile', nargs='?', default='-', type=argparse.FileType('r'),
                    help='file containing a MARS request or STDIN otherwise')

args = parser.parse_args()
req = args.infile.read()

if "WEBMARS_TARGET" in os.environ:
    target = os.environ["WEBMARS_TARGET"]
else:
    m = re.search('\\btar(g(e(t)?)?)?\s*=\s*([^\'",\s]+|"[^"]*"|\'[^\']*\')', req, re.I|re.M)
    if m is None:
        raise Exception("Cannot extract target")

    target=m.group(4)
    if target is None:
        raise Exception("Cannot extract target")

if target[0] == target[-1]:
    if target[0] in ['"', "'"]:
        target = target[1:-1]

c = ecmwfapi.ECMWFService('mars')
c.execute(req, target)

 You have to give execution permission to the file and put it in a location in your PATH.

If the file has been downloaded to ~/mars/bin, you have to execute:

Code Block
languagebash
titleMars
chmod +x ~/mars/bin/mars
export PATH=~/mars/bin/:$PATH


Anchor
apiclientlibrary
apiclientlibrary

Panel
titleColorwhite
titleBGColor#2B619E
titleInstall ECMWF API client library

Include Page
Install ECMWF Web API Python client library
Install ECMWF Web API Python client library

Anchor
key
key

Panel
titleColorwhite
titleBGColor#2B619E
titleInstall ECMWF KEY

Include Page
Install ECMWF API Key
Install ECMWF API Key

Anchor
testinstallation
testinstallation

Panel
titleColorwhite
titleBGColor#2B619E
titleTest installation

Example script

Retrieval of sea surface temperature for the first 10 days of May 2002, all synoptic times. It retrieves 40 fields.

Code Block
retrieve,
  class   = od,
  stream  = oper,
  expver  = 1,
  date    = 20020501/to/20020510,
  time    = 00/06/12/18,
  type    = an,
  levtype = sfc,
  param   = sea surface temperature,
  target  = "sst.grib"

Save this script as test.req and execute:

Code Block
languagebash
mars test.req

The command should generate a sst.grib file containing the retrieved 40 fields in GRIB format.

Expand
titleClick to see how to retrieve directly using Python...

You can use ECMWFService Python class to execute a retrieve command:

Code Block
languagepy
server = ECMWFService("mars")
server.execute({ "python":"query" }, "target")
# Alternatively the function execute can also accept a text variable with the request
server.execute(req,target)

Example: 


Code Block
languagepy
#!/usr/bin/env python
from ecmwfapi import ECMWFService
 
server = ECMWFService("mars")
server.execute(
    {
    "class": "od",
    "date": "20150101",
    "expver": "1",
    "levtype": "sfc",
    "param": "167.128",
    "step": "0/to/240/by/12",
    "stream": "oper",
    "time": "00",
    "type": "fc"
    },
    "target.grib")



Anchor
availability
availability

Panel
titleColorwhite
titleBGColor#2B619E
titleCheck availability

To check the Data availability you should have Access to the MARS Catalogue. Please note that the MARS catalogue is a super-set of the Archive catalogue.

Info

Archive Catalogue

MARS Catalogue (restricted to authorised users)

you will view all the experiments that are available from our archive. We strongly recommend you to to navigate through MARS Catalogue to become familiar with the availability of our archive. You may select a class and start navigate trough the contents. 

Please take into account some considerations about the content: 

  • Different class and stream include different parameters, times, and steps  
  • In each class not all the parameters are available from all steps   
  • In each class and stream not all the steps are available from all times

The web-application above will help you to check and understand the availability. For any kind of selections the system will update the attributes in a dynamic way to reflect the current availability. (i.e. if you change the steps some parameters will be added or removed).

Info
titleTip

We encourage users to use the " View MARS request " feature once the selection has been done.

You can also use list action with output=cost keyword to see the available data and its cost without need to retrieve it. This is useful to check the amount of data and number of tapes that your request will need to access. If your request takes longer than expected, it is a good practice to check its cost.

Expand
titleexpand list action...


Code Block
list,
  class   = od,
  stream  = oper,
  expver  = 1,
  date    = 20020501/to/20020510,
  time    = 00/06/12/18,
  type    = an,
  levtype = sfc,
  param   = sea surface temperature,
  output  = cost,
  target  = "sst.list"


Expand
titleList verb with Python...


Code Block
languagepy
#!/usr/bin/env python

from ecmwfapi import ECMWFService
 
server = ECMWFService("mars")
req = '''
list,
  class   = od,
  stream  = oper,
  expver  = 1,
  date    = 20020501/to/20020510,
  time    = 00/06/12/18,
  type    = an,
  levtype = sfc,
  param   = sea surface temperature,
  output  = cost
'''
server.execute(req, "sst.list")


This would produce something like:

Code Block
size=21599920;
number_of_fields=40;
online_size=21599920;
off_line_size=0;
number_of_tape_files=0;
number_of_disk_files=1;
number_of_online_fields=40;
number_of_offline_fields=0;
number_of_tapes=0;

Indicating that the size of this request will be 20.59 Mb (output is in Kb) and that it is fully located in the online disk (no need to access any tape).

Warning

Bear in mind that the maximum value of number_of_tapes recommended is 1 tape per request and should not exceed 3. Otherwise we strongly encourage you to split it in several different requests iterating by date.

If you do not set the "output=cost" keyword on the list action, the output will show you information about the type of requests and the entries:

Code Block
languagebash
titlesst.list
class   = od
expver  = 1
file[0] = hpss:/mars/prod/od/o/oper/an/sfc/marsodoper/1/an/20020501/sfc/126665.20031108.113424
id      = 126665
levtype = sfc
month   = 200205
stream  = oper
type    = an
year    = 2002
date       file length missing offset     param  time     
2002-05-01 0    539998 .       4729126    34.128 00:00:00 
2002-05-01 0    539998 .       37233582   34.128 06:00:00 
2002-05-01 0    539998 .       69738038   34.128 12:00:00 
2002-05-01 0    539998 .       102242494  34.128 18:00:00 
2002-05-02 0    539998 .       134746950  34.128 00:00:00 
2002-05-02 0    539998 .       167251406  34.128 06:00:00 
2002-05-02 0    539998 .       199755862  34.128 12:00:00 
2002-05-02 0    539998 .       232260318  34.128 18:00:00 
2002-05-03 0    539998 .       264764774  34.128 00:00:00 
2002-05-03 0    539998 .       297269230  34.128 06:00:00 
2002-05-03 0    539998 .       329773686  34.128 12:00:00 
2002-05-03 0    539998 .       362278142  34.128 18:00:00 
2002-05-04 0    539998 .       394782598  34.128 00:00:00 
2002-05-04 0    539998 .       427287054  34.128 06:00:00 
2002-05-04 0    539998 .       459791510  34.128 12:00:00 
2002-05-04 0    539998 .       492295966  34.128 18:00:00 
2002-05-05 0    539998 .       524800422  34.128 00:00:00 
2002-05-05 0    539998 .       557304878  34.128 06:00:00 
2002-05-05 0    539998 .       589809334  34.128 12:00:00 
2002-05-05 0    539998 .       622313790  34.128 18:00:00 
2002-05-06 0    539998 .       654818246  34.128 00:00:00 
2002-05-06 0    539998 .       687322702  34.128 06:00:00 
2002-05-06 0    539998 .       719827158  34.128 12:00:00 
2002-05-06 0    539998 .       752331614  34.128 18:00:00 
2002-05-07 0    539998 .       784836070  34.128 00:00:00 
2002-05-07 0    539998 .       817340526  34.128 06:00:00 
2002-05-07 0    539998 .       849844982  34.128 12:00:00 
2002-05-07 0    539998 .       882349438  34.128 18:00:00 
2002-05-08 0    539998 .       914853894  34.128 00:00:00 
2002-05-08 0    539998 .       947358350  34.128 06:00:00 
2002-05-08 0    539998 .       979862806  34.128 12:00:00 
2002-05-08 0    539998 .       1012367262 34.128 18:00:00 
2002-05-09 0    539998 .       1044871718 34.128 00:00:00 
2002-05-09 0    539998 .       1077376174 34.128 06:00:00 
2002-05-09 0    539998 .       1109880630 34.128 12:00:00 
2002-05-09 0    539998 .       1142385086 34.128 18:00:00 
2002-05-10 0    539998 .       1174889542 34.128 00:00:00 
2002-05-10 0    539998 .       1207393998 34.128 06:00:00 
2002-05-10 0    539998 .       1239898454 34.128 12:00:00 
2002-05-10 0    539998 .       1272402910 34.128 18:00:00 

Grand Total:
============

Entries       : 40
Total         : 21,599,920 (20.5993 Mbytes)


Spend some time to understand how it works, make some selections try to execute the MARS scripts.

Anchor
examples
examples

Panel
bgColorwhite
titleColorwhite
titleBGColor#2B619E
titleMARS examples


Expand
titleClick here to see examples...


Section


Column


Panel
titleColorwhite
titleBGColor#2B619E
title40 year re-analysis

 Retrieval of snow depth from the ERA-40 archive for November 1993, for all analysis base times. It retrieves 120 fields. See in MARS Catalogue

Code Block
languagejava
retrieve,
  class   = e4,
  stream  = oper,
  expver  = 1,
  date    = 19931101/to/19931130,
  time    = 00/06/12/18,
  type    = an,
  levtype = sfc,
  param   = sd,
  repres  = gg,
  target  = "era40.199311.sd"



Panel
titleColorwhite
titleBGColor#2B619E
titleOperational Analysis

 Retrieval of sea surface temperature for the first 10 days of May 2002, all synoptic times. It retrieves 40 fields. See in MARS Catalogue

Code Block
languagejava
retrieve,
  class   = od,
  stream  = oper,
  expver  = 1,
  date    = 20020501/to/20020510,
  time    = 00/06/12/18,
  type    = an,
  levtype = sfc,
  param   = sea surface temperature,
  target  = "sst"




Column


Panel
titleColorwhite
titleBGColor#2B619E
titleEnsemble Forecast

Retrieval of surface temperature an 10m wind components (U and V), 20 first members of the EPS for 2nd January 2001 for time-steps 12, 36 and 60. It retrieves 180 fields. See in MARS Catalogue

Code Block
languagejava
retrieve,
  class   = od,
  stream  = enfo,
  expver  = 1,
  date    = 20010102,
  time    = 12,
  step    = 12/36/60,
  type    = pf,
  levtype = sfc,
  param   = st/10u/10v,
  number  = 1/to/20,
  target  = "perturbed.sfc"



Panel
titleColorwhite
titleBGColor#2B619E
titleSnow depth 1 month

 Retrieval of snow depth from the ERA-Interim archive for December 2007, for all analysis base times. It retrieves 124 fields. See in MARS Catalogue

Code Block
languagejava
retrieve,
class   = ei,
stream  = oper,
expver  = 1,
date    = 20071201/to/20071231
time    = 00/06/12/18,
type    = an,
levtype = sfc,
param   = sd,
target  = "era-int.200712.sd"






Hide content


Click here to see Python examples...


white#2B619EPython retrieve

Retrieve 1000,850,700 and 500 hPa temperatures from the 15th of February 1999 12 UTC Analysis

py




You can find more advanced examples here: MARS example requests


Info

We strongly suggest users to split their requests by date e.g. one month at a time.

If you want to get big chunks of data, please have a look to the Retrieval efficiency page.


Anchor
requestsyntax
requestsyntax

Panel
titleColorwhite
titleBGColor#2B619E
titleBrief MARS request syntax

See Brief MARS request syntax page.

Anchor
documentation
documentation

Panel
titleColorwhite
titleBGColor#2B619E
titleDocumentation

Training material (slides, pdf): MARS introduction and basic concepts

Mars manual

MARS FAQ

Web API FAQ

Content by Label
showLabelsfalse
max5
spaces~uscs
showSpacefalse
sortmodified
reversetrue
typepage
cqllabel in ("web","mars","api") and type = "page" and space = "~uscs"
labelsWEB API MARS

Page properties
hiddentrue


Related issues




Panel
titleColorwhite
titleBGColor#2B619E
titleContact


Panel
titleColorwhite
titleBGColor#2B619E

Livesearch
spaceKeyWEBAPI
placeholderSearch for ...


Panel
titleColorwhite
titleBGColor#2B619E
titleUseful links


New window link
Linkhttps://confluence.ecmwf.int/display/WEBAPI/Web+API+FAQ
Web API FAQ



New window link
Linkhttps://software.ecmwf.int/wiki/display/UDOC/MARS+user+documentation
What is MARS?



Download mars script


New window link
Linkhttp://www.ecmwf.int/en/forecasts/accessing-forecasts
Accessing Forecasts



Brief MARS request syntax


New window link
Linkhttps://api.ecmwf.int/v1/key/
ECMWF API Key



New window link
Linkhttps://software.ecmwf.int/wiki/download/attachments/45748923/mars.pdf
[SLIDES] MARS introduction and basic concepts



New window link
Linkhttps://software.ecmwf.int/wiki/display/UDOC/MARS+user+documentation
MARS Manual 



Panel
titleColorwhite
titleBGColor#2B619E
titleWebAPI UPDATES

Include Page
News feed
News feed


Panel
titleColorwhite
titleBGColor#2B619E

Recently Updated
max5