The Atmosphere Data Store (ADS) is the cornerstone infrastructure which supports the implementation of the Copernicus Atmosphere Monitoring Service (CAMS). It is built on the same infrastructure as the Climate Data Store (CDS). It enables the provision of reliable data and expertise related to air quality, solar energy, and the role atmospheric gases and particles play in climate change.
The ADS :
The data provided by the ADS are free and open data, subject to the user agreeing to the relevant dataset licence(s). For further details about the underlying infrastructure, please see this article from the ECMWF Newsletter 151.
The ADS provides a Catalogue which lists CAMS data and products, such as observations, reanalyses and air quality forecasts. Users can search through the catalogue, and can filter the entries by means of both a faceted search (Variable domain, Parameter family, Spatial coverage, Product type, Temporal coverage) and a textual search.
Users can request data from the ADS using a variety of methods:
1) The ADS web interface is an interactive system: the user fills a web form to construct their query (please note that only a valid query can be submitted via the web form).
Please make sure that you select all the mandatory fields before submit a request. ![]() |
The user can then currently choose between two options:
In the future, a third option - the ADS Toolbox - will be added.
These are shown in the following figures:
Figure 1 Web interface | Figure 2 Request options on the web interface |
2) The CDS API is a service providing programmatic access in Python to ADS data. Users need to have a CDS account to use it with their related CDS API credentials. For a full description and some useful examples, please see How to use the CDS API.
If users have more than one ADS API key (e.g. you also have a Climate Data Store (CDS) account), you have to pass credentials in explicitly and the following method can be used:
import cdsapi import yaml with open('/path/to/ads/cdsapirc', 'r') as f: credentials = yaml.safe_load(f) c = cdsapi.Client(url=credentials['url'], key=credentials['key']) c.retrieve("dataset-short-name", {... sub-selection request ...}, "target-file") |
We strongly suggest to construct CDS API requests by using the web interface of the relevant dataset and using the 'Show API request' button to get the code.
For non-Python users, please note that the CDS API is REST-based so it can be wrapped by any programming language. Please see this example with the R package: Download CDS ERA5 data using R.
Users can also set the PROXY within the CDS API script:
import requests import cdsapi session = requests.Session() session.proxies = { 'http': 'http://10.10.10.10:8000', 'https': 'http://10.10.10.10:8000', } client = cdsapi.Client(session=session) |
Please note: Currently, all ADS datasets are covered by Copernicus Products Licence, and users have to accept it in order to be able to download datasets (whether through the web interface, or the CDS API). If the licence has not been accepted, the error message below will shown by the CDS API: At the time this article was written, the acceptance of the licence can only be carried out through the ADS web interface for the relevant dataset, by forming a request on the "Download data" page. The user will then be prompted to accept the licence. Once that is done, the CDS API request can be successfully submitted to the ADS. |
As the ADS is a distributed platform, the datasets are hosted at a number of different locations. Some data are stored on the ADS disks themselves; others are hosted remotely on the data providers' storage systems, e.g. the ECMWF Meteorological Archival and Retrieval System (MARS).
Table 2 shows where the ADS datasets are currently stored.
Please note that the items the user selects to include in a single ADS request can make a significant difference in terms of performance i.e. how long a given request will take to run. Please see the page Efficiency tips for how to build an efficient request.
On the ADS cache disks, requests and relevant results are generally stored for 1.5 to 2 days, depending on the user load on the ADS system. After this period, files can be deleted, starting from the oldest.
Please note that cached data (if present) is used to fulfill an ADS request only if the ADS request is exactly identical to a previous one. This means that data will be extracted from the cache, rather than being re-retrieved from the dataset itself.
After sending a request, the user can track its state on the 'Your Requests' page of the ADS web interface. There are five different states of a request:
User can check the live status of the ADS queues here https://ads.atmosphere.copernicus.eu/live/queue.
Users can also check the overall status of the ADS system at the live page.
Please note:
|
Limits are set on usage of ADS resources to ensure an appropriate level of performance for users.
They are divided in three categories: 1) per-user, 2) global and 3) system, and the current values for these limits are shown in Table 1 (last reviewed on ).
Please note that these limits are changed from time to time according to the current workload of the system and number of concurrent tasks.
The ADS will queue requests which would otherwise cause any of these limits to be exceeded.
The 'live' status of the limits values can be checked here https://ads.atmosphere.copernicus.eu/live/limits
|
Also, ADS data requests have limits in terms of number of fields and volume size, which are different for each dataset (see the "Datasets" Table 2 below). These values are dependent on each dataset's structure and where the dataset is actually stored. Again, these restrictions are introduced to help the system maintain good performance and minimise the queuing time for all users.
Please note, that these limits are also enforced for requests sent via the CDS API.
Table 2 Summary of the number of fields limits, as well as the major features of all ADS datasets (last reviewed on 26 April 2023)
Dataset | Number of fields limit | Volume size limit | Adaptor (indicates where the data are stored; see "Efficiency Tips" below) | Notes |
10000 | 175 GB for GRIB files, 30 GB for netCDF files | MARS Internal/external | Those variables listed as fast-access are readily available from ADS disks. Those variables listed as slow-access and data older than 30 days are stored in ECMWF MARS tape archive. | |
100000 | 175 GB for GRIB files, 30 GB for netCDF files | MARS Internal/external | Those variables listed as fast-access are readily available from ADS disks. Those variables listed as slow-access are stored in ECMWF MARS tape archive. | |
100000 | 175 GB for GRIB files, 30 GB for netCDF files | MARS Internal | N/A | |
CAMS global inversion-optimised greenhouse gas fluxes and concentrations | 500 | N/A | adaptor.url | Stored locally on ADS disks |
100000 | 175 GB for GRIB files, 30 GB for netCDF files | MARS external | Data are stored in ECMWF MARS tape archive | |
CAMS global greenhouse gas reanalysis (EGG4) monthly averaged fields | 100000 | 175 GB for GRIB files, 30 GB for netCDF files | MARS external | Data are stored in ECMWF MARS tape archive |
10000 | N/A | adaptor.cams_solar_rad2.retrieve | This data is calculated on demand by a service jointly provided by DLR, Armines, and Transvalor. The ADS forwards requests to this service and returns the data from it. | |
5000 | N/A | adaptor.cams_regional_fc.retrieve | There are three classes of speed at which these requests will be processed:
| |
1000 | N/A | adaptor.url | Check the documentation for data availability | |
1000 | N/A | adaptor.url2.retrieve | N/A | |
1000 | N/A | adaptor.url | ||
1000 | N/A | adaptor.url |
CDS API Request for sulphate aerosol optical depth 550nm from CAMS global reanalysis (EAC4) dataset on on 01-01-2004, at 00 UTC.
import cdsapi c = cdsapi.Client() c.retrieve( 'cams-global-reanalysis-eac4', { 'variable': 'sulphate_aerosol_optical_depth_550nm', 'date': '2004-01-18/2004-01-18', 'time': '00:00', 'format': 'netcdf', }, 'download.nc') |
This document has been produced in the context of the Copernicus Atmosphere Monitoring Service (CAMS). The activities leading to these results have been contracted by the European Centre for Medium-Range Weather Forecasts, operator of CAMS on behalf of the European Union (Delegation Agreement signed on 11/11/2014 and Contribution Agreement signed on 22/07/2021). All information in this document is provided "as is" and no guarantee or warranty is given that the information is fit for any particular purpose. The users thereof use the information at their sole risk and liability. For the avoidance of all doubt , the European Commission and the European Centre for Medium - Range Weather Forecasts have no liability in respect of this document, which is merely representing the author's view. |