From 6ce9ee2320e82c72a93ab15dd3993f401201bb92 Mon Sep 17 00:00:00 2001 From: Denis Nadeau Date: Wed, 21 Mar 2018 17:09:14 -0700 Subject: [PATCH] Merge changes to release 3.3.2 (#326) * update to 3.2.9 in cmor.h * update tables to 01.00.17 * use CdUnif * fix Table memory * fix Table version 6.0 to 6.2 * Fix licences and conventions; Fix memory issue * insure that cdms2 is not loaded * update tables * fix cronjob message for CMIP6_CV push * update to version 3.3.0 * use 1024 character, fix regex * Make sure buffer does not overflow due to license * Add multiprocessing to PrePARE * pep8 code * create parallelization for PrePARE * fix typo * Fix basin integer missing value; add test; move code around in PrePARE.py * update test tables * fix conda recipe * pinning anaconda-client to 1.6.5 due to network issue * check in source section is defined in CV souce_id * fix external variable issue * add test for branch_time... * fix climatology issue * change geo_region to sector * update upload scripts * add then to script * fix travis; branch_time.. message; license(OSX) * use gcc_linux-64 * try miniconda 4.3.21 * change docker to centos 6.8 * change branch_time message * Cleanup code and arguments. "cmip6_table" positional input has been removed to avoid conflicts with multiprocessing. * Cleanup code and arguments. Rollback table path option to file or dir. Pass variable flag in process if submitted. Append prints to logfile instead of truncate it. * Reformat code * set .h to 3.3.2 * fix type, fix PrePARE branch_ metadata * fix type, fix PrePARE branch_ metadata * merge * put back some lost code in merging * Add "OR" support for cell_measures comparison + Add input filters * Replace set_CV_error by self.cv_error * Some PEP008 rewriting * Bugfix on 'OR' support for cell_measures * Proper "cell_methods" comparison without or without text in parentheses * fix return code for parallel/sequentiel * fix cell measures * pep8 PrePARE * Add safe return code * add error code to check_cv; merge Guillaume's branch * update tables to 01.00.23 * fix climatology issue for monotonic files --- Lib/pywrapper.py | 2 +- LibCV/PrePARE/PrePARE.py | 802 ++++++++++++---------- LibCV/pywrapper.py | 2 +- Src/_controlvocabulary.c | 52 +- Src/cmor_variables.c | 19 +- Test/test_non_monotonic_climo_bonds_ok.py | 5 +- Test/test_site_ts.py | 6 +- TestTables/CMIP6_3hr.json | 18 +- TestTables/CMIP6_6hrLev.json | 26 +- TestTables/CMIP6_6hrPlev.json | 12 +- TestTables/CMIP6_6hrPlevPt.json | 26 +- TestTables/CMIP6_AERday.json | 12 +- TestTables/CMIP6_AERhr.json | 12 +- TestTables/CMIP6_AERmon.json | 136 ++-- TestTables/CMIP6_AERmonZ.json | 26 +- TestTables/CMIP6_Amon.json | 40 +- TestTables/CMIP6_CF3hr.json | 20 +- TestTables/CMIP6_CFday.json | 14 +- TestTables/CMIP6_CFmon.json | 8 +- TestTables/CMIP6_CFsubhr.json | 28 +- TestTables/CMIP6_E1hr.json | 16 +- TestTables/CMIP6_E1hrClimMon.json | 6 +- TestTables/CMIP6_E3hr.json | 10 +- TestTables/CMIP6_E3hrPt.json | 54 +- TestTables/CMIP6_E6hrZ.json | 6 +- TestTables/CMIP6_Eday.json | 98 +-- TestTables/CMIP6_EdayZ.json | 22 +- TestTables/CMIP6_Efx.json | 36 +- TestTables/CMIP6_Emon.json | 312 ++++----- TestTables/CMIP6_EmonZ.json | 16 +- TestTables/CMIP6_Esubhr.json | 20 +- TestTables/CMIP6_Eyr.json | 8 +- TestTables/CMIP6_IfxAnt.json | 6 +- TestTables/CMIP6_IfxGre.json | 6 +- TestTables/CMIP6_ImonAnt.json | 18 +- TestTables/CMIP6_ImonGre.json | 18 +- TestTables/CMIP6_IyrAnt.json | 8 +- TestTables/CMIP6_IyrGre.json | 8 +- TestTables/CMIP6_LImon.json | 12 +- TestTables/CMIP6_Lmon.json | 8 +- TestTables/CMIP6_Oclim.json | 6 +- TestTables/CMIP6_Oday.json | 8 +- TestTables/CMIP6_Odec.json | 126 +++- TestTables/CMIP6_Ofx.json | 12 +- TestTables/CMIP6_Omon.json | 526 +++++++------- TestTables/CMIP6_Oyr.json | 54 +- TestTables/CMIP6_SIday.json | 6 +- TestTables/CMIP6_SImon.json | 36 +- TestTables/CMIP6_coordinate.json | 58 +- TestTables/CMIP6_day.json | 24 +- TestTables/CMIP6_formula_terms.json | 6 +- TestTables/CMIP6_fx.json | 8 +- TestTables/CMIP6_grids.json | 6 +- configure | 18 +- configure.ac | 2 +- include/cmor.h | 2 +- 56 files changed, 1478 insertions(+), 1374 deletions(-) mode change 100644 => 100755 LibCV/PrePARE/PrePARE.py diff --git a/Lib/pywrapper.py b/Lib/pywrapper.py index 095da903..0800285c 100644 --- a/Lib/pywrapper.py +++ b/Lib/pywrapper.py @@ -616,7 +616,7 @@ def zfactor(zaxis_id, zfactor_name, units="", axis_ids=None, type = 'd' if not isinstance(type, str): - raise Exception("error tpye must a a string") + raise Exception("error type must a string") type = type.lower() if type == 's': type = 'c' diff --git a/LibCV/PrePARE/PrePARE.py b/LibCV/PrePARE/PrePARE.py old mode 100644 new mode 100755 index a3ff6170..bba485bd --- a/LibCV/PrePARE/PrePARE.py +++ b/LibCV/PrePARE/PrePARE.py @@ -11,123 +11,64 @@ # python CMIP6Validtor ../Tables/CMIP6_Amon.json ../CMIP6/yourfile.nc # -''' +""" Created on Fri Feb 19 11:33:52 2016 @author: Denis Nadeau LLNL @co-author: Guillaume Levavasseur (IPSL) Parallelization -''' + +""" + +import argparse +import itertools +import json +import os import re import sys +from argparse import ArgumentTypeError from contextlib import contextmanager +from multiprocessing import Pool +from uuid import uuid4 as uuid + +import numpy # Make sure cdms2.__init__py is not loaded when importing Cdunif sys.path.insert(0, sys.prefix + "/lib/python2.7/site-packages/cdms2") import Cdunif -import argparse -import os -import json -import numpy import cmip6_cv -from multiprocessing import Pool - - -class bcolors: - HEADER = '\033[95m' - OKBLUE = '\033[94m' - OKGREEN = '\033[1;32m' - WARNING = '\033[1;34;47m' - FAIL = '\033[1;31;47m' - ENDC = '\033[0m' - BOLD = '\033[1m' - UNDERLINE = '\033[4m' - -# ========================= -# FILEAction() -# ========================= -class FILEAction(argparse.Action): - ''' - Check if argparse is JSON file - ''' - - def __call__(self, parser, namespace, values, option_string=None): - fn = values - if not os.path.isfile(fn): - raise argparse.ArgumentTypeError( - 'FILEAction:{0} is file not found'.format(fn)) - f = open(fn) - lines = f.readlines() - f.close() - setattr(namespace, self.dest, lines) - -# ========================= -# JSONAction() -# ========================= -class JSONAction(argparse.Action): - ''' - Check if argparse is JSON file - ''' - - def __call__(self, parser, namespace, values, option_string=None): - fn = values - if not os.path.isfile(fn): - raise argparse.ArgumentTypeError( - 'JSONAction:{0} is file not found'.format(fn)) - f = open(fn) - lines = f.readlines() - f.close() - jsonobject = json.loads(" ".join(lines)) - if not jsonobject: - raise argparse.ArgumentTypeError( - 'JSONAction:{0} is file not a valid JSON file'.format(fn)) - setattr(namespace, self.dest, values) # ========================= -# CDMSAction() +# BColors() # ========================= -class CDMSAction(argparse.Action): - ''' - Check if argparse is CDMS file - ''' +class BColors: + """ + Background colors for print statements - def __call__(self, parser, namespace, values, option_string=None): - fn = values - if not os.path.isfile(fn): - raise argparse.ArgumentTypeError( - 'CDMSAction:{0} does not exist'.format(fn)) - f = Cdunif.CdunifFile(fn, "r") - f.close() - setattr(namespace, self.dest, fn) + """ + def __init__(self): + self.HEADER = '\033[95m' + self.OKBLUE = '\033[94m' + self.OKGREEN = '\033[1;32m' + self.WARNING = '\033[1;34;47m' + self.FAIL = '\033[1;31;47m' + self.ENDC = '\033[0m' + self.BOLD = '\033[1m' + self.UNDERLINE = '\033[4m' -# ========================= -# readable_dir() -# ========================= -class readable_dir(argparse.Action): - ''' - Check if argparse is a directory. - ''' - def __call__(self, parser, namespace, values, option_string=None): - prospective_dir = values - if not os.path.isdir(prospective_dir): - raise argparse.ArgumentTypeError( - 'readable_dir:{0} is not a valid path'.format(prospective_dir)) - if os.access(prospective_dir, os.R_OK): - setattr(namespace, self.dest, prospective_dir) - else: - raise argparse.ArgumentTypeError( - 'readable_dir:{0} is not a readable dir'.format(prospective_dir)) +BCOLORS = BColors() # ========================= # DIRAction() # ========================= class DIRECTORYAction(argparse.Action): - ''' + """ Check if argparse is a directory. - ''' + + """ def __call__(self, parser, namespace, values, option_string=None): prospective = values @@ -147,9 +88,10 @@ def __call__(self, parser, namespace, values, option_string=None): # INPUTAction() # ========================= class INPUTAction(argparse.Action): - ''' + """ Checks if the supplied input exists. - ''' + + """ def __call__(self, parser, namespace, values, option_string=None): checked_values = [self.input_checker(x) for x in values] @@ -174,27 +116,76 @@ class Collector(object): :param list sources: The list of sources to parse :returns: The data collector :rtype: *iter* + """ def __init__(self, sources, data=None): self.sources = sources self.data = data + self.FileFilter = FilterCollection() + self.PathFilter = FilterCollection() assert isinstance(self.sources, list) def __iter__(self): for source in self.sources: if os.path.isdir(source): - # If input is a directory: walk through it and yields netCDF - # files + # If input is a directory: walk through it and yields netCDF files for root, _, filenames in os.walk(source, followlinks=True): - for filename in sorted(filenames): - ffp = os.path.join(root, filename) - if os.path.isfile(ffp) and re.search( - re.compile('^.*\.nc$'), filename): - yield (ffp, self.data) + if self.PathFilter(root): + for filename in sorted(filenames): + ffp = os.path.join(root, filename) + if os.path.isfile(ffp) and self.FileFilter(filename): + yield (ffp, self.data) else: # It input is a file: yields the netCDF file itself - yield (source, self.data) + root, filename = os.path.split(source) + if self.PathFilter(root) and self.FileFilter(filename): + yield (source, self.data) + + def __len__(self): + """ + Returns collector length. + + :returns: The number of items in the collector. + :rtype: *int* + + """ + s = 0 + for _ in self.__iter__(): + s += 1 + return s + + +class FilterCollection(object): + """ + Regex dictionary with a call method to evaluate a string against several regular expressions. + The dictionary values are 2-tuples with the regular expression as a string and a boolean + indicating to match (i.e., include) or non-match (i.e., exclude) the corresponding expression. + + """ + FILTER_TYPES = (str, re._pattern_type) + + def __init__(self): + self.filters = dict() + + def add(self, name=None, regex='*', inclusive=True): + """Add new filter""" + if not name: + name = uuid() + assert isinstance(regex, self.FILTER_TYPES) + assert isinstance(inclusive, bool) + self.filters[name] = (regex, inclusive) + + def __call__(self, string): + return all([self.match(regex, string, inclusive=inclusive) for regex, inclusive in self.filters.values()]) + + @staticmethod + def match(pattern, string, inclusive=True): + # Assert inclusive and exclusive flag are mutually exclusive + if inclusive: + return True if re.search(pattern, string) else False + else: + return True if not re.search(pattern, string) else False # ========================= @@ -217,11 +208,12 @@ def next(self): sys.stdout.flush() Spinner.step += 1 + # ========================= # checkCMIP6() # ========================= class checkCMIP6(object): - ''' + """ Validate if a file is CMIP6 compliant and ready for publication. Class need to read CMIP6 Table and Controled Vocabulary file. @@ -236,17 +228,23 @@ class checkCMIP6(object): Output: outfile: Log file, default is stdout. - ''' + """ - # ************************* - # __init__() - # ************************* def __init__(self, table_path): # ------------------------------------------------------------------- - # Initilaze table path + # Reset CV error switch + # ------------------------------------------------------------------- + self.cv_error = False + # ------------------------------------------------------------------- + # Initialize table path # ------------------------------------------------------------------- self.cmip6_table_path = os.path.normpath(table_path) # ------------------------------------------------------------------- + # Initialize attributes dictionaries + # ------------------------------------------------------------------- + self.dictGbl = dict() + self.dictVars = dict() + # ------------------------------------------------------------------- # call setup() to clean all 'C' internal memory. # ------------------------------------------------------------------- cmip6_cv.setup(inpath="../Tables", exit_control=cmip6_cv.CMOR_NORMAL) @@ -281,7 +279,7 @@ def _get_table_from_filename(f): return f.split('_')[1] @staticmethod - def _check_JSON_table(path): + def _check_json_table(path): f = open(path) lines = f.readlines() f.close() @@ -290,310 +288,334 @@ def _check_JSON_table(path): raise argparse.ArgumentTypeError( 'Invalid JSON CMOR table: {}'.format(path)) - def setDoubleValue(self, attribute): - if (cmip6_cv.has_cur_dataset_attribute(attribute)): - if (isinstance(self.dictGbl[attribute], numpy.ndarray) and isinstance(self.dictGbl[attribute][0], - numpy.float64)): + def set_double_value(self, attribute): + if cmip6_cv.has_cur_dataset_attribute(attribute): + if isinstance(self.dictGbl[attribute], numpy.ndarray) and \ + isinstance(self.dictGbl[attribute][0], numpy.float64): self.dictGbl[attribute] = self.dictGbl[attribute][0] - cmip6_cv.set_cur_dataset_attribute( - attribute, self.dictGbl[attribute]) - - def ControlVocab(self, ncfile): - ''' - Check CMIP6 global attributes against Control Vocabulary file. - - 1. Validate required attribute if presents and some values. - 2. Validate registered institution and institution_id - 3. Validate registered source and source_id - 4. Validate experiment, experiment_id and all attributes associated with this experiment. - Make sure that all attributes associate with the experiment_id found in CMIP6_CV.json - are set to the appropriate values. - 5. Validate grid_label and grid_resolution - 6. Validate creation time in ISO format (YYYY-MM-DDTHH:MM:SS) - 7. Validate furtherinfourl from CV internal template - 8. Validate variable attributes with CMOR JSON table. - 9. Validate parent_* attribute - 10. Validate sub_experiment_* atributes. - 11. Validate that all *_index are integers. - ''' + cmip6_cv.set_cur_dataset_attribute(attribute, self.dictGbl[attribute]) + + def ControlVocab(self, ncfile, variable=None): + """ + Check CMIP6 global attributes against Control Vocabulary file. + + 1. Validate required attribute if presents and some values. + 2. Validate registered institution and institution_id + 3. Validate registered source and source_id + 4. Validate experiment, experiment_id and all attributes associated with this experiment. + Make sure that all attributes associate with the experiment_id found in CMIP6_CV.json + are set to the appropriate values. + 5. Validate grid_label and grid_resolution + 6. Validate creation time in ISO format (YYYY-MM-DDTHH:MM:SS) + 7. Validate furtherinfourl from CV internal template + 8. Validate variable attributes with CMOR JSON table. + 9. Validate parent_* attribute + 10. Validate sub_experiment_* attributes. + 11. Validate that all *_index are integers. + + """ + err = 0 filename = os.path.basename(ncfile) # ------------------------------------------------------------------- - # Initilaze arrays + # Initialize arrays # ------------------------------------------------------------------- - if os.path.isfile(self.cmip6_table_path): - self.cmip6_table = self.cmip6_table_path - else: - self.cmip6_table = '{}/CMIP6_{}.json'.format( + # If table_path is the table directory + # Deduce corresponding JSON from filename + if os.path.isdir(self.cmip6_table_path): + cmip6_table = '{}/CMIP6_{}.json'.format( self.cmip6_table_path, self._get_table_from_filename(filename)) - - self._check_JSON_table(self.cmip6_table) + else: + cmip6_table = self.cmip6_table_path + # Check JSON file + self._check_json_table(cmip6_table) # ------------------------------------------------------------------- # Load CMIP6 table into memory # ------------------------------------------------------------------- - self.table_id = cmip6_cv.load_table(self.cmip6_table) + table_id = cmip6_cv.load_table(cmip6_table) # ------------------------------------------------------------------- # Deduce variable # ------------------------------------------------------------------- - self.variable = self._get_variable_from_filename(filename) + # If variable can be deduced from the filename (Default) + if not variable: + variable = self._get_variable_from_filename(filename) + else: + # If variable submitted on command line with --variable + variable = variable + # ------------------------------------------------------------------- + # Is a climatology? + # ------------------------------------------------------------------- climatology = False - if( filename.find('-clim') != -1 ): + if filename.find('-clim') != -1: climatology = True - if( self.cmip6_table.find('Amon') != -1): - self.variable = self.variable + 'Clim' - + if cmip6_table.find('Amon') != -1: + variable = '{}Clim'.format(variable) # ------------------------------------------------------------------- # Open file in processing # ------------------------------------------------------------------- - self.infile = Cdunif.CdunifFile(ncfile, "r") - # ------------------------------------- - # Create alist of all Global Attributes - # ------------------------------------- - self.dictGbl = {key: self.infile.__dict__[ - key] for key in self.infile.__dict__.keys()} - self.attributes = self.infile.__dict__.keys() - self.variables = self.infile.variables.keys() - ierr = [ - cmip6_cv.set_cur_dataset_attribute( - key, - value) for key, - value in self.dictGbl.iteritems()] + infile = Cdunif.CdunifFile(ncfile, "r") + # -------------------------------------- + # Create a list of all Global Attributes + # -------------------------------------- + self.dictGbl = infile.__dict__ + for key, value in self.dictGbl.iteritems(): + cmip6_cv.set_cur_dataset_attribute(key, value) + # Set member_id attribute depending on sub_experiment_id and variant_label member_id = "" - if ("sub_experiment_id" in self.dictGbl.keys()): - if (self.dictGbl["sub_experiment_id"] not in ["none"]): - member_id = self.dictGbl["sub_experiment_id"] + \ - '-' + self.dictGbl["variant_label"] + if "sub_experiment_id" in self.dictGbl.keys(): + if self.dictGbl["sub_experiment_id"] not in ['none']: + member_id = '{}-{}'.format(self.dictGbl['sub_experiment_id'], + self.dictGbl['variant_label']) else: - member_id = self.dictGbl["variant_label"] - cmip6_cv.set_cur_dataset_attribute( - cmip6_cv.GLOBAL_ATT_MEMBER_ID, member_id) - self.setDoubleValue('branch_time_in_parent') - self.setDoubleValue('branch_time_in_child') - if self.variable is not None: - self.var = [self.variable] + member_id = self.dictGbl['variant_label'] + cmip6_cv.set_cur_dataset_attribute(cmip6_cv.GLOBAL_ATT_MEMBER_ID, member_id) + self.set_double_value('branch_time_in_parent') + self.set_double_value('branch_time_in_child') + if variable is not None: + var = [variable] else: # ------------------------------------------------------------------- # find variable that contains a "history" (should only be one) # ------------------------------------------------------------------- - self.var = [self.infile.variable_id] - - climPos = self.var[0].find('Clim') - if climatology and climPos != -1: - self.var = [self.var[0][:climPos]] - - if ((self.var == []) or (len(self.var) > 1)): - print bcolors.FAIL - print "!!!!!!!!!!!!!!!!!!!!!!!!!" - print "! Error: The input file does not have an history attribute and the CMIP6 variable could not be found" - print "! Please use the --variable option to specify your CMIP6 variable" - print "! Check your file or use CMOR 3.x to achieve compliance for ESGF publication." - print "!!!!!!!!!!!!!!!!!!!!!!!!!" - print bcolors.ENDC + var = [infile.variable_id] + + clim_idx = var[0].find('Clim') + if climatology and clim_idx != -1: + var = [var[0][:clim_idx]] + + if var == [] or len(var) > 1: + print BCOLORS.FAIL + print "=====================================================================================" + print "The input file does not have an history attribute and the CMIP6 variable could not be found" + print "Please use the --variable option to specify your CMIP6 variable" + print "=====================================================================================" + print BCOLORS.ENDC raise KeyboardInterrupt try: - self.keys = self.infile.variables[self.var[0]].__dict__.keys() + var_keys = infile.variables[var[0]].__dict__.keys() except BaseException: - print bcolors.FAIL - print "!!!!!!!!!!!!!!!!!!!!!!!!!" - print "! Error: The variable " + self.var[0] + " could not be found" - print "! Check your file variables " - print "!!!!!!!!!!!!!!!!!!!!!!!!!" - print bcolors.ENDC + print BCOLORS.FAIL + print "=====================================================================================" + print "The variable " + var[0] + " could not be found" + print "=====================================================================================" + print BCOLORS.ENDC raise KeyboardInterrupt # ------------------------------------------------------------------- - # Create a dictionnary of attributes for var + # Create a dictionary of attributes for var # ------------------------------------------------------------------- self.dictVars = dict((y, x) for y, x in - [(key, value) for key in self.keys - if self.infile.variables[self.var[0]].__dict__[key] is not None - for value in [self.infile.variables[self.var[0]].__dict__[key]]]) + [(key, value) for key in var_keys + if infile.variables[var[0]].__dict__[key] is not None + for value in [infile.variables[var[0]].__dict__[key]]]) try: - self.calendar = self.infile.variables['time'].calendar - self.timeunits = self.infile.variables['time'].units + calendar = infile.variables['time'].calendar + timeunits = infile.variables['time'].units except BaseException: - self.calendar = "gregorian" - self.timeunits = "days since ?" - cmip6_cv.check_requiredattributes(self.table_id) - cmip6_cv.check_institution(self.table_id) - cmip6_cv.check_sourceID(self.table_id) - cmip6_cv.check_experiment(self.table_id) - cmip6_cv.check_grids(self.table_id) - cmip6_cv.check_ISOTime() - cmip6_cv.check_furtherinfourl(self.table_id) - cmip6_cv.check_parentExpID(self.table_id) - cmip6_cv.check_subExpID(self.table_id) + calendar = "gregorian" + timeunits = "days since ?" + err += cmip6_cv.check_requiredattributes(table_id) + err += cmip6_cv.check_institution(table_id) + err += cmip6_cv.check_sourceID(table_id) + err += cmip6_cv.check_experiment(table_id) + err += cmip6_cv.check_grids(table_id) + err += cmip6_cv.check_ISOTime() + err += cmip6_cv.check_furtherinfourl(table_id) + err += cmip6_cv.check_parentExpID(table_id) + err += cmip6_cv.check_subExpID(table_id) try: if climatology: - startimebnds = self.infile.variables['climatology_bnds'][0][0] - endtimebnds = self.infile.variables['climatology_bnds'][-1][1] + startimebnds = infile.variables['climatology_bnds'][0][0] + endtimebnds = infile.variables['climatology_bnds'][-1][1] else: - startimebnds = self.infile.variables['time_bnds'][0][0] - endtimebnds = self.infile.variables['time_bnds'][-1][1] + startimebnds = infile.variables['time_bnds'][0][0] + endtimebnds = infile.variables['time_bnds'][-1][1] except BaseException: startimebnds = 0 endtimebnds = 0 - + try: - startime = self.infile.variables['time'][0] - endtime = self.infile.variables['time'][-1] + startime = infile.variables['time'][0] + endtime = infile.variables['time'][-1] except BaseException: startime = 0 endtime = 0 - varunits = self.infile.variables[self.var[0]].units - varmissing = self.infile.variables[self.var[0]]._FillValue[0] + varunits = infile.variables[var[0]].units + varmissing = infile.variables[var[0]]._FillValue[0] # ------------------------------------------------- - # Make sure with use self.variable for Climatology + # Make sure with use variable for Climatology # ------------------------------------------------- - varid = cmip6_cv.setup_variable(self.variable, varunits, varmissing, startime, endtime, + varid = cmip6_cv.setup_variable(variable, varunits, varmissing, startime, endtime, startimebnds, endtimebnds) - if (varid == -1): - print bcolors.FAIL + if varid == -1: + print BCOLORS.FAIL print "=====================================================================================" - print " Could not find variable '%s' in table '%s' " % (self.var[0], self.cmip6_table) + print "Could not find variable '%s' in table '%s' " % (var[0], cmip6_table) print "=====================================================================================" - print bcolors.ENDC - cmip6_cv.set_CV_Error() + print BCOLORS.ENDC + self.cv_error = True raise KeyboardInterrupt - fn = os.path.basename(str(self.infile).split('\'')[1]) - cmip6_cv.check_filename( - self.table_id, + fn = os.path.basename(str(infile).split('\'')[1]) + err += cmip6_cv.check_filename( + table_id, varid, - self.calendar, - self.timeunits, + calendar, + timeunits, fn) + if err != 0: + self.cv_error = True - if not isinstance(self.dictGbl['branch_time_in_child'], numpy.float64): - print bcolors.FAIL - print "=====================================================================================" - print "branch_time_in_child is not a double: ", type(self.dictGbl['branch_time_in_child']) - print "=====================================================================================" - print bcolors.ENDC - cmip6_cv.set_CV_Error() + if 'branch_time_in_child' in self.dictGbl.keys(): + if not isinstance(self.dictGbl['branch_time_in_child'], numpy.float64): + print BCOLORS.FAIL + print "=====================================================================================" + print "branch_time_in_child is not a double: ", type(self.dictGbl['branch_time_in_child']) + print "=====================================================================================" + print BCOLORS.ENDC + self.cv_error = True - if not isinstance(self.dictGbl['branch_time_in_parent'], numpy.float64): - print bcolors.FAIL - print "=====================================================================================" - print "branch_time_in_parent is not an double: ", type(self.dictGbl['branch_time_in_parent']) - print "=====================================================================================" - print bcolors.ENDC - cmip6_cv.set_CV_Error() + if 'branch_time_in_parent' in self.dictGbl.keys(): + if not isinstance(self.dictGbl['branch_time_in_parent'], numpy.float64): + print BCOLORS.FAIL + print "=====================================================================================" + print "branch_time_in_parent is not an double: ", type(self.dictGbl['branch_time_in_parent']) + print "=====================================================================================" + print BCOLORS.ENDC + self.cv_error = True if not isinstance(self.dictGbl['realization_index'], numpy.ndarray): - print bcolors.FAIL + print BCOLORS.FAIL print "=====================================================================================" print "realization_index is not an integer: ", type(self.dictGbl['realization_index']) print "=====================================================================================" - print bcolors.ENDC - cmip6_cv.set_CV_Error() + print BCOLORS.ENDC + self.cv_error = True if not isinstance(self.dictGbl['initialization_index'], numpy.ndarray): - print bcolors.FAIL + print BCOLORS.FAIL print "=====================================================================================" print "initialization_index is not an integer: ", type(self.dictGbl['initialization_index']) print "=====================================================================================" - print bcolors.ENDC - cmip6_cv.set_CV_Error() + print BCOLORS.ENDC + self.cv_error = True if not isinstance(self.dictGbl['physics_index'], numpy.ndarray): - print bcolors.FAIL + print BCOLORS.FAIL print "=====================================================================================" print "physics_index is not an integer: ", type(self.dictGbl['physics_index']) print "=====================================================================================" - print bcolors.ENDC - cmip6_cv.set_CV_Error() + print BCOLORS.ENDC + self.cv_error = True if not isinstance(self.dictGbl['forcing_index'], numpy.ndarray): - print bcolors.FAIL + print BCOLORS.FAIL print "=====================================================================================" print "forcing_index is not an integer: ", type(self.dictGbl['forcing_index']) print "=====================================================================================" - print bcolors.ENDC - cmip6_cv.set_CV_Error() + print BCOLORS.ENDC + self.cv_error = True # ----------------------------- # variable attribute comparison # ----------------------------- - prepLIST = cmip6_cv.list_variable_attributes(varid) - for key in prepLIST: - if(key == "long_name"): + cv_attrs = cmip6_cv.list_variable_attributes(varid) + for key in cv_attrs: + if key == "long_name": continue - if(key == "comment"): + if key == "comment": continue - # Is this attritue in file? - if(key in self.dictVars.keys()): + if key == "cell_measures": + if cv_attrs[key].find("OPT") != -1 or cv_attrs[key].find("MODEL") != -1: + continue + # Is this attribute in file? + if key in self.dictVars.keys(): # Verify that attribute value is equal to file attribute - table_value = prepLIST[key] + table_value = cv_attrs[key] file_value = self.dictVars[key] # PrePARE accept units of 1 or 1.0 so adjust thet table_value # ----------------------------------------------------------- - if(key == "units"): - if((table_value == "1") and (file_value == "1.0")): - table_value = "1.0" - if((table_value == "1.0") and (file_value == "1")): - table_value = "1" + if key == "units": + if (table_value == "1") and (file_value == "1.0"): + table_value = "1.0" + if (table_value == "1.0") and (file_value == "1"): + table_value = "1" if isinstance(table_value, str) and isinstance(file_value, numpy.ndarray): - if(numpy.array([int(value) for value in table_value.split()] == file_value).all()): - file_value=True - table_value=True + if numpy.array([int(value) for value in table_value.split()] == file_value).all(): + file_value = True + table_value = True if isinstance(table_value, numpy.ndarray): table_value = table_value[0] if isinstance(file_value, numpy.ndarray): file_value = file_value[0] if isinstance(table_value, float): - if(file_value == 0): - if(table_value != file_value): + if file_value == 0: + if table_value != file_value: file_value = False else: - if(1 - (table_value / file_value) < 0.00001): + if 1 - (table_value / file_value) < 0.00001: table_value = file_value if key == "cell_methods": - idx = file_value.find(" (interval:") - file_value = file_value[:idx] - table_value = table_value[:idx] - - file_value = str(file_value) - table_value = str(table_value) - if table_value != file_value: - print bcolors.FAIL + idx = file_value.find(" (") + if idx != -1: + file_value = file_value[:idx] + table_value = table_value[:idx] + + if key == "cell_measures": + pattern = re.compile('(?P[\w.-]+): (?P[\w.-]+) OR (?P[\w.-]+)') + values = re.findall(pattern, table_value) + table_values = [""] # Empty string is allowed in case of useless attribute + if values: + tmp = dict() + for param, val1, val2 in values: + tmp[param] = [str('{}: {}'.format(param, val1)), str('{}: {}'.format(param, val2))] + table_values.extend([' '.join(i) for i in list(itertools.product(*tmp.values()))]) + if str(file_value) not in map(str, table_values): + print BCOLORS.FAIL + print "=====================================================================================" + print "Your file contains \"" + key + "\":\"" + str(file_value) + "\" and" + print "CMIP6 tables requires \"" + key + "\":\"" + str(table_value) + "\"." + print "=====================================================================================" + print BCOLORS.ENDC + self.cv_error = True + continue + + if str(table_value) != str(file_value): + print BCOLORS.FAIL print "=====================================================================================" print "Your file contains \"" + key + "\":\"" + str(file_value) + "\" and" print "CMIP6 tables requires \"" + key + "\":\"" + str(table_value) + "\"." print "=====================================================================================" - print bcolors.ENDC - cmip6_cv.set_CV_Error() + print BCOLORS.ENDC + self.cv_error = True else: # That attribute is not in the file - table_value = prepLIST[key] - if key == "cell_measures": - if((table_value.find("OPT") != -1) or (table_value.find("MODEL") != -1)): - continue + table_value = cv_attrs[key] if isinstance(table_value, numpy.ndarray): table_value = table_value[0] if isinstance(table_value, float): table_value = "{0:.2g}".format(table_value) - print bcolors.FAIL + print BCOLORS.FAIL print "=====================================================================================" - print "CMIP6 variable " + self.var[0] + " requires \"" + key + "\":\"" + str(table_value) + "\"." + print "CMIP6 variable " + var[0] + " requires \"" + key + "\":\"" + str(table_value) + "\"." print "=====================================================================================" - print bcolors.ENDC - cmip6_cv.set_CV_Error() + print BCOLORS.ENDC + self.cv_error = True - if(cmip6_cv.get_CV_Error()): + if self.cv_error: raise KeyboardInterrupt else: - print bcolors.OKGREEN + print BCOLORS.OKGREEN print "*************************************************************************************" print "* This file is compliant with the CMIP6 specification and can be published in ESGF *" print "*************************************************************************************" - print bcolors.ENDC + print BCOLORS.ENDC def process(source): @@ -601,90 +623,115 @@ def process(source): # process logfile = '/tmp/PrePARE-{}.log'.format(os.getpid()) with RedirectedOutput(logfile): - try: - # Deserialize inputs - ncfile, table_path = source - print "Processing: {}\n".format(ncfile) - # Process file - checker = checkCMIP6(table_path) - checker.ControlVocab(ncfile) - except KeyboardInterrupt: - print bcolors.FAIL - print "*************************************************************************************" - print "* Error: The input file is not CMIP6 compliant *" - print "* Check your file or use CMOR 3.x to achieve compliance for ESGF publication *" - print "*************************************************************************************" - print bcolors.ENDC - finally: - # Close opened file - if hasattr(checker, "infile"): - checker.infile.close() + rc = sequential_process(source) # Close and return logfile - return logfile + return logfile, rc def sequential_process(source): try: # Deserialize inputs - ncfile, table_path = source + ncfile, data = source + table_path, variable = data print "Processing: {}\n".format(ncfile) # Process file checker = checkCMIP6(table_path) - checker.ControlVocab(ncfile) + if variable: + checker.ControlVocab(ncfile, variable) + else: + checker.ControlVocab(ncfile) + return 0 except KeyboardInterrupt: - print bcolors.FAIL + print BCOLORS.FAIL print "*************************************************************************************" print "* Error: The input file is not CMIP6 compliant *" print "* Check your file or use CMOR 3.x to achieve compliance for ESGF publication *" print "*************************************************************************************" - print bcolors.ENDC + print BCOLORS.ENDC + return 1 finally: # Close opened file if hasattr(checker, "infile"): checker.infile.close() + +def regex_validator(string): + """ + Validates a Python regular expression syntax. + + :param str string: The string to check + :returns: The Python regex + :rtype: *re.compile* + :raises Error: If invalid regular expression + + """ + try: + return re.compile(string) + except re.error: + msg = 'Bad regex syntax: {}'.format(string) + raise ArgumentTypeError(msg) + + # ========================= # main() # ========================= - - def main(): - parser = argparse.ArgumentParser(prog='PrePARE', - description='Validate CMIP6 file ' - 'for ESGF publication.') - - parser.add_argument('--variable', - help='specify geophysical variable name') - - - parser.add_argument('--table_path', - help='Specify the CMIP6 CMOR tables path (JSON file).' - 'Default is "./Tables".', - action=DIRECTORYAction, - default='./Tables') - - parser.add_argument('--max-threads', - type=int, - default=1, - help='Number of maximal threads to simultaneously process several files.' - 'Default is one as sequential processing.') - - parser.add_argument('cmip6_table', - help='Specify the CMIP6 CMOR tables path (JSON file) or CMIP6 table file.' - 'Default is "./Tables".', - action=DIRECTORYAction, - default='./Tables') - - parser.add_argument('input', - help='Input CMIP6 netCDF data to validate (ex: clisccp_cfMon_DcppC22_NICAM_gn_200001-200001.nc.' - 'If a directory is submitted all netCDF recusively found will be validate independently.', - nargs='+', - action=INPUTAction) - -# parser.add_argument('outfile', -# help='Output file (default stdout)', -# type=argparse.FileType('w'), -# default=sys.stdout) + parser = argparse.ArgumentParser( + prog='PrePARE', + description='Validate CMIP6 file for ESGF publication.') + + parser.add_argument( + '--variable', + help='Specify geophysical variable name.\n' + 'If not variable is deduced from filename.') + + parser.add_argument( + '--table-path', + help='Specify the CMIP6 CMOR tables path (JSON file).\n' + 'If a directory is submitted table is deduced from filename (default is "./Tables").', + action=DIRECTORYAction, + default='./Tables') + + parser.add_argument( + '--max-threads', + type=int, + default=1, + help='Number of maximal threads to simultaneously process several files.\n' + 'Default is one as sequential processing.') + + parser.add_argument( + '--ignore-dir', + metavar="PYTHON_REGEX", + type=str, + default='^.*/\.[\w]*$', + help='Filter directories NON-matching the regular expression.\n' + 'Default ignores paths with folder name(s) starting with "."') + + parser.add_argument( + '--include-file', + metavar='PYTHON_REGEX', + type=regex_validator, + action='append', + help='Filter files matching the regular expression.\n' + 'Duplicate the flag to set several filters.\n' + 'Default only include NetCDF files.') + + parser.add_argument( + '--exclude-file', + metavar='PYTHON_REGEX', + type=regex_validator, + action='append', + help='Filter files NON-matching the regular expression.\n' + 'Duplicate the flag to set several filters.\n' + 'Default only exclude hidden files (with names not\n' + 'starting with ".").') + + parser.add_argument( + 'input', + help='Input CMIP6 netCDF data to validate (ex: clisccp_cfMon_DcppC22_NICAM_gn_200001-200001.nc).\n' + 'If a directory is submitted all netCDF recursively found will be validate independently.', + nargs='+', + action=INPUTAction) # Check command-line error try: @@ -695,20 +742,38 @@ def main(): except SystemExit: return 1 - if hasattr(args,"table_path"): - cmip6_table=args.table_path - # Collects netCDF files for process - sources = Collector(args.input, data=args.cmip6_table) + sources = Collector(args.input, data=(args.table_path, args.variable)) + # Set scan filters + file_filters = list() + if args.include_file: + file_filters.extend([(f, True) for f in args.include_file]) + else: + # Default includes netCDF only + file_filters.append(('^.*\.nc$', True)) + if args.exclude_file: + # Default exclude hidden files + file_filters.extend([(f, False) for f in args.exclude_file]) + else: + file_filters.append(('^\..*$', False)) + # Init collector file filter + for regex, inclusive in file_filters: + sources.FileFilter.add(regex=regex, inclusive=inclusive) + # Init collector dir filter + sources.PathFilter.add(regex=args.ignore_dir, inclusive=False) + nb_sources = len(sources) + errors = 0 + # Separate sequential process and multiprocessing if args.max_threads > 1: # Create pool of processes pool = Pool(int(args.max_threads)) # Run processes logfiles = list() progress = Spinner() - for logfile in pool.imap(process, sources): + for logfile, rc in pool.imap(process, sources): progress.next() logfiles.append(logfile) + errors += rc sys.stdout.write('\r\033[K') sys.stdout.flush() # Print results from logfiles and remove them @@ -721,7 +786,18 @@ def main(): pool.join() else: for source in sources: - sequential_process(source) + errors += sequential_process(source) + # Evaluate errors and exit with appropriate return code + if errors != 0: + if errors == nb_sources: + # All files has error(s). Error code = -1 + sys.exit(-1) + else: + # Some files (at least one) has error(s). Error code = nb files with error(s) + sys.exit(errors) + else: + # No errors. Error code = 0 + sys.exit(0) @contextmanager @@ -730,7 +806,7 @@ def RedirectedOutput(to=os.devnull): old_stdout = os.fdopen(os.dup(fd_out), 'w') fd_err = sys.stderr.fileno() old_stderr = os.fdopen(os.dup(fd_err), 'w') - stream = open(to, 'w') + stream = open(to, 'a+') sys.stdout.close() sys.stderr.close() os.dup2(stream.fileno(), fd_out) @@ -748,5 +824,5 @@ def RedirectedOutput(to=os.devnull): sys.stderr = os.fdopen(fd_err, 'w') -if (__name__ == '__main__'): - sys.exit(main()) +if __name__ == '__main__': + main() diff --git a/LibCV/pywrapper.py b/LibCV/pywrapper.py index e09e58a6..f3c6d238 100644 --- a/LibCV/pywrapper.py +++ b/LibCV/pywrapper.py @@ -318,7 +318,7 @@ def check_requiredattributes(table_id): Validate all required attributes against Control Vocabulary file. Usage: - cmip6_cv.check_gblattributes(table_id) + cmip6_cv.check_requiredattributes(table_id) Where: table_id is the table id returned by load_table() Return 0 on success diff --git a/Src/_controlvocabulary.c b/Src/_controlvocabulary.c index 0994b0d7..523827ef 100644 --- a/Src/_controlvocabulary.c +++ b/Src/_controlvocabulary.c @@ -20,6 +20,8 @@ static PyObject *PyCV_checkFilename(PyObject * self, PyObject * args) int nTimeCalLen; int nTimeUnitsLen; int ninfile; + int ierr; + cmor_is_setup(); if (!PyArg_ParseTuple(args, "iis#s#s#", &ntable, &varid, @@ -28,10 +30,10 @@ static PyObject *PyCV_checkFilename(PyObject * self, PyObject * args) return (Py_BuildValue("i", -1)); } - cmor_CV_checkFilename(cmor_tables[ntable].CV, varid, + ierr = cmor_CV_checkFilename(cmor_tables[ntable].CV, varid, szInTimeCalendar, szInTimeUnits, infile); - return (Py_BuildValue("i", 0)); + return (Py_BuildValue("i", ierr)); } /************************************************************************/ @@ -40,15 +42,16 @@ static PyObject *PyCV_checkFilename(PyObject * self, PyObject * args) static PyObject *PyCV_checkSubExpID(PyObject * self, PyObject * args) { int nVarRefTblID; + int ierr; cmor_is_setup(); if (!PyArg_ParseTuple(args, "i", &nVarRefTblID)) { return (Py_BuildValue("i", -1)); } - cmor_CV_checkSubExpID(cmor_tables[nVarRefTblID].CV); + ierr = cmor_CV_checkSubExpID(cmor_tables[nVarRefTblID].CV); - return (Py_BuildValue("i", 0)); + return (Py_BuildValue("i", ierr)); } /************************************************************************/ @@ -57,15 +60,16 @@ static PyObject *PyCV_checkSubExpID(PyObject * self, PyObject * args) static PyObject *PyCV_checkParentExpID(PyObject * self, PyObject * args) { int nVarRefTblID; + int ierr; cmor_is_setup(); if (!PyArg_ParseTuple(args, "i", &nVarRefTblID)) { return (Py_BuildValue("i", -1)); } - cmor_CV_checkParentExpID(cmor_tables[nVarRefTblID].CV); + ierr = cmor_CV_checkParentExpID(cmor_tables[nVarRefTblID].CV); - return (Py_BuildValue("i", 0)); + return (Py_BuildValue("i", ierr)); } /************************************************************************/ @@ -74,15 +78,16 @@ static PyObject *PyCV_checkParentExpID(PyObject * self, PyObject * args) static PyObject *PyCV_setInstitution(PyObject * self, PyObject * args) { int nVarRefTblID; + int ierr; cmor_is_setup(); if (!PyArg_ParseTuple(args, "i", &nVarRefTblID)) { return (Py_BuildValue("i", -1)); } - cmor_CV_setInstitution(cmor_tables[nVarRefTblID].CV); + ierr = cmor_CV_setInstitution(cmor_tables[nVarRefTblID].CV); - return (Py_BuildValue("i", 0)); + return (Py_BuildValue("i", ierr)); } /************************************************************************/ @@ -91,13 +96,14 @@ static PyObject *PyCV_setInstitution(PyObject * self, PyObject * args) static PyObject *PyCV_checkSourceID(PyObject * self, PyObject * args) { int nVarRefTblID; + int ierr; cmor_is_setup(); if (!PyArg_ParseTuple(args, "i", &nVarRefTblID)) { return (Py_BuildValue("i", -1)); } - cmor_CV_checkSourceID(cmor_tables[nVarRefTblID].CV); - return (Py_BuildValue("i", 0)); + ierr = cmor_CV_checkSourceID(cmor_tables[nVarRefTblID].CV); + return (Py_BuildValue("i", ierr)); } /************************************************************************/ @@ -106,15 +112,16 @@ static PyObject *PyCV_checkSourceID(PyObject * self, PyObject * args) static PyObject *PyCV_checkExperiment(PyObject * self, PyObject * args) { int nVarRefTblID; + int ierr; cmor_is_setup(); if (!PyArg_ParseTuple(args, "i", &nVarRefTblID)) { return (Py_BuildValue("i", -1)); } - cmor_CV_checkExperiment(cmor_tables[nVarRefTblID].CV); + ierr = cmor_CV_checkExperiment(cmor_tables[nVarRefTblID].CV); - return (Py_BuildValue("i", 0)); + return (Py_BuildValue("i", ierr)); } /************************************************************************/ @@ -123,15 +130,16 @@ static PyObject *PyCV_checkExperiment(PyObject * self, PyObject * args) static PyObject *PyCV_checkGrids(PyObject * self, PyObject * args) { int nVarRefTblID; + int ierr; cmor_is_setup(); if (!PyArg_ParseTuple(args, "i", &nVarRefTblID)) { return (Py_BuildValue("i", -1)); } - cmor_CV_checkGrids(cmor_tables[nVarRefTblID].CV); + ierr = cmor_CV_checkGrids(cmor_tables[nVarRefTblID].CV); - return (Py_BuildValue("i", 0)); + return (Py_BuildValue("i", ierr)); } /************************************************************************/ @@ -140,15 +148,17 @@ static PyObject *PyCV_checkGrids(PyObject * self, PyObject * args) static PyObject *PyCV_checkFurtherInfoURL(PyObject * self, PyObject * args) { int nVarRefTblID; + int ierr; + cmor_is_setup(); if (!PyArg_ParseTuple(args, "i", &nVarRefTblID)) { return (Py_BuildValue("i", -1)); } - cmor_CV_checkFurtherInfoURL(nVarRefTblID); + ierr = cmor_CV_checkFurtherInfoURL(nVarRefTblID); - return (Py_BuildValue("i", 0)); + return (Py_BuildValue("i", ierr)); } /************************************************************************/ @@ -157,15 +167,16 @@ static PyObject *PyCV_checkFurtherInfoURL(PyObject * self, PyObject * args) static PyObject *PyCV_GblAttributes(PyObject * self, PyObject * args) { int nVarRefTblID; + int ierr; cmor_is_setup(); if (!PyArg_ParseTuple(args, "i", &nVarRefTblID)) { return (Py_BuildValue("i", -1)); } - cmor_CV_checkGblAttributes(cmor_tables[nVarRefTblID].CV); + ierr = cmor_CV_checkGblAttributes(cmor_tables[nVarRefTblID].CV); - return (Py_BuildValue("i", 0)); + return (Py_BuildValue("i", ierr)); } /************************************************************************/ @@ -173,11 +184,12 @@ static PyObject *PyCV_GblAttributes(PyObject * self, PyObject * args) /************************************************************************/ static PyObject *PyCV_checkISOTime(PyObject * self, PyObject * args) { + int ierr; cmor_is_setup(); - cmor_CV_checkISOTime(GLOBAL_ATT_CREATION_DATE); + ierr = cmor_CV_checkISOTime(GLOBAL_ATT_CREATION_DATE); - return (Py_BuildValue("i", 0)); + return (Py_BuildValue("i", ierr)); } /************************************************************************/ diff --git a/Src/cmor_variables.c b/Src/cmor_variables.c index 9cdc37f4..2cb90599 100644 --- a/Src/cmor_variables.c +++ b/Src/cmor_variables.c @@ -2335,6 +2335,7 @@ int cmor_write_var_to_file(int ncid, cmor_var_t * avar, void *data, extern ut_system *ut_read; int tmpindex = 0; int index; + int bb; cmor_add_traceback("cmor_write_var_to_file"); cmor_is_setup(); @@ -2871,9 +2872,9 @@ int cmor_write_var_to_file(int ncid, cmor_var_t * avar, void *data, axes_ids[0]].iunits, msg, msg2, msg2); - ierr = cmor_check_monotonic(&tmp_vals[0], - (ntimes_passed + tmpindex) * 2, - "time", 1, avar->axes_ids[0]); + ierr = cmor_check_monotonic(&tmp_vals[0], + (ntimes_passed + tmpindex) * 2, + "time", 1, avar->axes_ids[0]); ierr = cmor_check_values_inside_bounds(&time_vals[0], &time_bounds[0], @@ -2948,19 +2949,7 @@ int cmor_write_var_to_file(int ncid, cmor_var_t * avar, void *data, cmor_handle_error(msg, CMOR_CRITICAL); } - if (cmor_tables[cmor_axes[avar->axes_ids[0]].ref_table_id].axes - [cmor_axes[avar->axes_ids[0]].ref_axis_id].climatology == - 1) { -/* -------------------------------------------------------------------- */ -/* all good in that case */ -/* -------------------------------------------------------------------- */ - } else { - - tmp_vals[ntimes_passed - 1] = - tmp_vals[ntimes_passed * 2 - 1]; - - } /* -------------------------------------------------------------------- */ /* ok now we need to store first and last stuff */ /* -------------------------------------------------------------------- */ diff --git a/Test/test_non_monotonic_climo_bonds_ok.py b/Test/test_non_monotonic_climo_bonds_ok.py index a3ae24b2..9b9cf9e8 100644 --- a/Test/test_non_monotonic_climo_bonds_ok.py +++ b/Test/test_non_monotonic_climo_bonds_ok.py @@ -43,8 +43,9 @@ def path_test(): data = numpy.array([3, 4, 5]) data.resize((3, 19, 1, 1)) # cmor.write(varid, data) - for i in range(len(data)): - cmor.write(varid, data[i], time_vals=times[i], time_bnds=times_bnds[i]) +# for i in range(len(data)): +# cmor.write(varid, data[i], time_vals=times[i], time_bnds=times_bnds[i]) + cmor.write(varid, data, time_vals=[12, 15, 18], time_bnds=[[10, 1234], [12, 1125], [15, 1128]]) path = cmor.close(varid, file_name=True) print path diff --git a/Test/test_site_ts.py b/Test/test_site_ts.py index 188c3d69..df507b9d 100644 --- a/Test/test_site_ts.py +++ b/Test/test_site_ts.py @@ -18,7 +18,7 @@ def setup_data(): 'coord_vals': [0]}, {'table_entry': 'hybrid_height', 'units': 'm', - 'coord_vals': range(2), + 'coord_vals': numpy.array(range(2), dtype=numpy.float64), 'cell_bounds': [[x - 0.5, x + 0.5] for x in range(2)], }, ] @@ -38,11 +38,11 @@ def cmor_define_and_write(values, axes): igrid = cmor.grid([axis_ids[1]], [0.], [0.]) cmor.zfactor(axis_ids[2], 'b', axis_ids=[axis_ids[2]], - zfactor_values=range(2), + zfactor_values=numpy.array(range(2), dtype=numpy.float64), zfactor_bounds=[[x - 0.5, x + 0.5] for x in range(2)]) cmor.zfactor(axis_ids[2], 'orog', 'm', axis_ids=[igrid], - zfactor_values=[0]) + zfactor_values=[0.] ) ids_for_var = [axis_ids[0], igrid, axis_ids[2]] varid = cmor.variable('tnhus', diff --git a/TestTables/CMIP6_3hr.json b/TestTables/CMIP6_3hr.json index d08a0734..885dec62 100644 --- a/TestTables/CMIP6_3hr.json +++ b/TestTables/CMIP6_3hr.json @@ -1,10 +1,10 @@ { "Header": { - "data_specs_version": "01.00.21", + "data_specs_version": "01.00.23", + "cmor_version": "3.3", "table_id": "Table 3hr", "realm": "atmos", - "cmor_version": "3.2", - "table_date": "14 February 2018", + "table_date": "21 March 2018", "missing_value": "1e20", "int_missing_value": "-999", "product": "model-output", @@ -40,7 +40,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "Surface Upward Latent Heat Flux", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'Upward' indicates a vector component which is positive when directed upward (negative downward). The surface latent heat flux is the exchange of heat between the surface and the air on account of evaporation (including sublimation). In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "longitude latitude time", "out_name": "hfls", "type": "real", @@ -58,7 +58,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "Surface Upward Sensible Heat Flux", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'Upward' indicates a vector component which is positive when directed upward (negative downward). The surface sensible heat flux, also called 'turbulent' heat flux, is the exchange of heat between the surface and the air by motion of air. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics. Unless indicated in the cell_methods attribute, a quantity is assumed to apply to the whole area of each horizontal grid box. Previously, the qualifier where_type was used to specify that the quantity applies only to the part of the grid box of the named type. Names containing the where_type qualifier are deprecated and newly created data should use the cell_methods attribute to indicate the horizontal area to which the quantity applies.", "dimensions": "longitude latitude time", "out_name": "hfss", "type": "real", @@ -202,7 +202,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "Surface Downwelling Longwave Radiation", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'longwave' means longwave radiation. Downwelling radiation is radiation from above. It does not mean 'net downward'. When thought of as being incident on a surface, a radiative flux is sometimes called 'irradiance'. In addition, it is identical with the quantity measured by a cosine-collector light-meter and sometimes called 'vector irradiance'. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "longitude latitude time", "out_name": "rlds", "type": "real", @@ -238,7 +238,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "Surface Upwelling Longwave Radiation", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'longwave' means longwave radiation. Upwelling radiation is radiation from below. It does not mean 'net upward'. When thought of as being incident on a surface, a radiative flux is sometimes called 'irradiance'. In addition, it is identical with the quantity measured by a cosine-collector light-meter and sometimes called 'vector irradiance'. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "longitude latitude time", "out_name": "rlus", "type": "real", @@ -310,7 +310,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "Surface Upwelling Shortwave Radiation", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'shortwave' means shortwave radiation. Upwelling radiation is radiation from below. It does not mean 'net upward'. When thought of as being incident on a surface, a radiative flux is sometimes called 'irradiance'. In addition, it is identical with the quantity measured by a cosine-collector light-meter and sometimes called 'vector irradiance'. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "longitude latitude time", "out_name": "rsus", "type": "real", @@ -362,7 +362,7 @@ "standard_name": "sea_surface_temperature", "units": "degC", "cell_methods": "area: mean where sea time: point", - "cell_measures": "area: areacella", + "cell_measures": "area: areacello", "long_name": "Sea Surface Temperature", "comment": "Temperature of upper boundary of the liquid ocean, including temperatures below sea-ice and floating ice shelves.", "dimensions": "longitude latitude time1", diff --git a/TestTables/CMIP6_6hrLev.json b/TestTables/CMIP6_6hrLev.json index 56df651f..4c673c1c 100644 --- a/TestTables/CMIP6_6hrLev.json +++ b/TestTables/CMIP6_6hrLev.json @@ -1,10 +1,10 @@ { "Header": { - "data_specs_version": "01.00.21", + "data_specs_version": "01.00.23", + "cmor_version": "3.3", "table_id": "Table 6hrLev", "realm": "atmos", - "cmor_version": "3.2", - "table_date": "14 February 2018", + "table_date": "21 March 2018", "missing_value": "1e20", "int_missing_value": "-999", "product": "model-output", @@ -15,15 +15,15 @@ }, "variable_entry": { "bs550aer": { - "frequency": "6hrPt", + "frequency": "6hr", "modeling_realm": "aerosol", "standard_name": "volume_lidar_backwards_scattering_coefficient_in_air_due_to_ambient_aerosol_particles", "units": "m-1 sr-1", - "cell_methods": "area: mean time: point", + "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "Aerosol backscatter coefficient", "comment": "Aerosol Backscatter at 550nm and 180 degrees, computed from extinction and lidar ratio", - "dimensions": "longitude latitude alevel time1", + "dimensions": "longitude latitude time lambda550nm", "out_name": "bs550aer", "type": "real", "positive": "", @@ -41,7 +41,7 @@ "cell_measures": "area: areacella", "long_name": "Aerosol extinction coefficient", "comment": "Aerosol Extinction at 550nm", - "dimensions": "longitude latitude alevel time1", + "dimensions": "longitude latitude alevel time1 lambda550nm", "out_name": "ec550aer", "type": "real", "positive": "", @@ -58,7 +58,7 @@ "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", "long_name": "Specific Humidity", - "comment": "", + "comment": "'specific' means per unit mass. Specific humidity is the mass fraction of water vapor in (moist) air.", "dimensions": "longitude latitude alevel time1", "out_name": "hus", "type": "real", @@ -69,15 +69,15 @@ "ok_max_mean_abs": "" }, "pfull": { - "frequency": "6hr", + "frequency": "6hrPt", "modeling_realm": "atmos", "standard_name": "air_pressure", "units": "Pa", - "cell_methods": "area: time: mean", + "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", "long_name": "Air Pressure", "comment": "Air pressure on model levels", - "dimensions": "longitude latitude alevel time", + "dimensions": "longitude latitude alevel time1", "out_name": "pfull", "type": "real", "positive": "", @@ -130,7 +130,7 @@ "cell_methods": "time: point", "cell_measures": "--OPT", "long_name": "Eastward Wind", - "comment": "", + "comment": "'Eastward' indicates a vector component which is positive when directed eastward (negative westward). Wind is defined as a two-dimensional (horizontal) air velocity vector, with no vertical component. (Vertical motion in the atmosphere has the standard name upward_air_velocity.)", "dimensions": "longitude latitude alevel time1", "out_name": "ua", "type": "real", @@ -148,7 +148,7 @@ "cell_methods": "time: point", "cell_measures": "--OPT", "long_name": "Northward Wind", - "comment": "", + "comment": "'Northward' indicates a vector component which is positive when directed northward (negative southward). Wind is defined as a two-dimensional (horizontal) air velocity vector, with no vertical component. (Vertical motion in the atmosphere has the standard name upward_air_velocity.)", "dimensions": "longitude latitude alevel time1", "out_name": "va", "type": "real", diff --git a/TestTables/CMIP6_6hrPlev.json b/TestTables/CMIP6_6hrPlev.json index 1e7d3e67..ebd1d6be 100644 --- a/TestTables/CMIP6_6hrPlev.json +++ b/TestTables/CMIP6_6hrPlev.json @@ -1,10 +1,10 @@ { "Header": { - "data_specs_version": "01.00.21", + "data_specs_version": "01.00.23", + "cmor_version": "3.3", "table_id": "Table 6hrPlev", "realm": "atmos", - "cmor_version": "3.2", - "table_date": "14 February 2018", + "table_date": "21 March 2018", "missing_value": "1e20", "int_missing_value": "-999", "product": "model-output", @@ -58,7 +58,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "Specific Humidity", - "comment": "", + "comment": "'specific' means per unit mass. Specific humidity is the mass fraction of water vapor in (moist) air.", "dimensions": "longitude latitude plev4 time", "out_name": "hus", "type": "real", @@ -94,7 +94,7 @@ "cell_methods": "area: mean time: mean within hours time: maximum over hours", "cell_measures": "area: areacella", "long_name": "Maximum Hourly Precipitation Rate", - "comment": "", + "comment": "In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "longitude latitude time", "out_name": "prhmax", "type": "real", @@ -130,7 +130,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "Relative Vorticity at 850 hPa", - "comment": "", + "comment": "Relative vorticity is the upward component of the vorticity vector i.e. the component which arises from horizontal velocity.", "dimensions": "longitude latitude time p850", "out_name": "rv850", "type": "real", diff --git a/TestTables/CMIP6_6hrPlevPt.json b/TestTables/CMIP6_6hrPlevPt.json index 16846a82..ea9e45a3 100644 --- a/TestTables/CMIP6_6hrPlevPt.json +++ b/TestTables/CMIP6_6hrPlevPt.json @@ -1,10 +1,10 @@ { "Header": { - "data_specs_version": "01.00.21", + "data_specs_version": "01.00.23", + "cmor_version": "3.3", "table_id": "Table 6hrPlevPt", "realm": "atmos", - "cmor_version": "3.2", - "table_date": "14 February 2018", + "table_date": "21 March 2018", "missing_value": "1e20", "int_missing_value": "-999", "product": "model-output", @@ -112,7 +112,7 @@ "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", "long_name": "Specific Humidity", - "comment": "", + "comment": "'specific' means per unit mass. Specific humidity is the mass fraction of water vapor in (moist) air.", "dimensions": "longitude latitude plev27 time1", "out_name": "hus", "type": "real", @@ -130,7 +130,7 @@ "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", "long_name": "Specific Humidity", - "comment": "", + "comment": "'specific' means per unit mass. Specific humidity is the mass fraction of water vapor in (moist) air.", "dimensions": "longitude latitude plev7h time1", "out_name": "hus", "type": "real", @@ -274,7 +274,7 @@ "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", "long_name": "Relative Vorticity at 850 hPa", - "comment": "", + "comment": "Relative vorticity is the upward component of the vorticity vector i.e. the component which arises from horizontal velocity.", "dimensions": "longitude latitude time1 p850", "out_name": "rv850", "type": "real", @@ -341,7 +341,7 @@ "swsffluxaero": { "frequency": "6hrPt", "modeling_realm": "atmos", - "standard_name": "shortwave__flux_due_to_volcanic_aerosols_at__the_surface", + "standard_name": "shortwave__flux_due_to_volcanic_ambient_aerosol_particles_at_the_surface", "units": "W m-2", "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", @@ -490,7 +490,7 @@ "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", "long_name": "Eastward Wind", - "comment": "", + "comment": "'Eastward' indicates a vector component which is positive when directed eastward (negative westward). Wind is defined as a two-dimensional (horizontal) air velocity vector, with no vertical component. (Vertical motion in the atmosphere has the standard name upward_air_velocity.)", "dimensions": "longitude latitude plev3 time1", "out_name": "ua", "type": "real", @@ -508,7 +508,7 @@ "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", "long_name": "Eastward Wind", - "comment": "", + "comment": "'Eastward' indicates a vector component which is positive when directed eastward (negative westward). Wind is defined as a two-dimensional (horizontal) air velocity vector, with no vertical component. (Vertical motion in the atmosphere has the standard name upward_air_velocity.)", "dimensions": "longitude latitude plev7h time1", "out_name": "ua", "type": "real", @@ -544,7 +544,7 @@ "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", "long_name": "Northward Wind", - "comment": "", + "comment": "'Northward' indicates a vector component which is positive when directed northward (negative southward). Wind is defined as a two-dimensional (horizontal) air velocity vector, with no vertical component. (Vertical motion in the atmosphere has the standard name upward_air_velocity.)", "dimensions": "longitude latitude plev3 time1", "out_name": "va", "type": "real", @@ -562,7 +562,7 @@ "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", "long_name": "Northward Wind", - "comment": "", + "comment": "'Northward' indicates a vector component which is positive when directed northward (negative southward). Wind is defined as a two-dimensional (horizontal) air velocity vector, with no vertical component. (Vertical motion in the atmosphere has the standard name upward_air_velocity.)", "dimensions": "longitude latitude plev7h time1", "out_name": "va", "type": "real", @@ -634,7 +634,7 @@ "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", "long_name": "Geopotential Height", - "comment": "", + "comment": "Geopotential is the sum of the specific gravitational potential energy relative to the geoid and the specific centripetal potential energy. Geopotential height is the geopotential divided by the standard acceleration due to gravity. It is numerically similar to the altitude (or geometric height) and not to the quantity with standard name height, which is relative to the surface.", "dimensions": "longitude latitude plev27 time1", "out_name": "zg", "type": "real", @@ -670,7 +670,7 @@ "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", "long_name": "Geopotential Height", - "comment": "", + "comment": "Geopotential is the sum of the specific gravitational potential energy relative to the geoid and the specific centripetal potential energy. Geopotential height is the geopotential divided by the standard acceleration due to gravity. It is numerically similar to the altitude (or geometric height) and not to the quantity with standard name height, which is relative to the surface.", "dimensions": "longitude latitude plev7h time1", "out_name": "zg", "type": "real", diff --git a/TestTables/CMIP6_AERday.json b/TestTables/CMIP6_AERday.json index 441d43b7..c8de258c 100644 --- a/TestTables/CMIP6_AERday.json +++ b/TestTables/CMIP6_AERday.json @@ -1,10 +1,10 @@ { "Header": { - "data_specs_version": "01.00.21", + "data_specs_version": "01.00.23", + "cmor_version": "3.3", "table_id": "Table AERday", "realm": "aerosol", - "cmor_version": "3.2", - "table_date": "14 February 2018", + "table_date": "21 March 2018", "missing_value": "1e20", "int_missing_value": "-999", "product": "model-output", @@ -22,7 +22,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "cloud optical depth", - "comment": "", + "comment": "The optical thickness is the integral along the path of radiation of a volume scattering/absorption/attenuation coefficient. The radiative flux is reduced by a factor exp(-optical_thickness) on traversing the path. A coordinate variable of radiation_wavelength or radiation_frequency can be specified to indicate that the optical thickness applies at specific wavelengths or frequencies. The atmosphere optical thickness applies to radiation passing through the entire atmosphere. 'Cloud' means the component of extinction owing to the presence of liquid or ice water particles. The specification of a physical process by the phrase due_to_process means that the quantity named is a single term in a sum of terms which together compose the general quantity named by omitting the phrase.", "dimensions": "longitude latitude time", "out_name": "cod", "type": "real", @@ -77,7 +77,7 @@ "cell_measures": "area: areacella", "long_name": "ambient aerosol optical thickness at 550 nm", "comment": "AOD from the ambient aerosols (i.e., includes aerosol water). Does not include AOD from stratospheric aerosols if these are prescribed but includes other possible background aerosol types. Needs a comment attribute 'wavelength: 550 nm'", - "dimensions": "longitude latitude time", + "dimensions": "longitude latitude time lambda550nm", "out_name": "od550aer", "type": "real", "positive": "", @@ -94,7 +94,7 @@ "cell_methods": "area: mean time: maximum", "cell_measures": "area: areacella", "long_name": "daily maximum O3 volume mixing ratio in lowest model layer", - "comment": "", + "comment": "Mole fraction is used in the construction mole_fraction_of_X_in_Y, where X is a material constituent of Y.", "dimensions": "longitude latitude time", "out_name": "sfo3max", "type": "real", diff --git a/TestTables/CMIP6_AERhr.json b/TestTables/CMIP6_AERhr.json index eee84907..bb782a12 100644 --- a/TestTables/CMIP6_AERhr.json +++ b/TestTables/CMIP6_AERhr.json @@ -1,10 +1,10 @@ { "Header": { - "data_specs_version": "01.00.21", + "data_specs_version": "01.00.23", + "cmor_version": "3.3", "table_id": "Table AERhr", "realm": "aerosol", - "cmor_version": "3.2", - "table_date": "14 February 2018", + "table_date": "21 March 2018", "missing_value": "1e20", "int_missing_value": "-999", "product": "model-output", @@ -40,7 +40,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "NO2 volume mixing ratio in lowest model layer", - "comment": "", + "comment": "Mole fraction is used in the construction mole_fraction_of_X_in_Y, where X is a material constituent of Y.", "dimensions": "longitude latitude time", "out_name": "sfno2", "type": "real", @@ -58,7 +58,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "O3 volume mixing ratio in lowest model layer", - "comment": "", + "comment": "Mole fraction is used in the construction mole_fraction_of_X_in_Y, where X is a material constituent of Y.", "dimensions": "longitude latitude time", "out_name": "sfo3", "type": "real", @@ -76,7 +76,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "PM2.5 mass mixing ratio in lowest model layer", - "comment": "", + "comment": "Mass fraction is used in the construction mass_fraction_of_X_in_Y, where X is a material constituent of Y. It means the ratio of the mass of X to the mass of Y (including X). A chemical species denoted by X may be described by a single term such as 'nitrogen' or a phrase such as 'nox_expressed_as_nitrogen'. 'Aerosol' means the system of suspended liquid or solid particles in air (except cloud droplets) and their carrier gas, the air itself. 'Ambient_aerosol' means that the aerosol is measured or modelled at the ambient state of pressure, temperature and relative humidity that exists in its immediate environment. 'Ambient aerosol particles' are aerosol particles that have taken up ambient water through hygroscopic growth. The extent of hygroscopic growth depends on the relative humidity and the composition of the particles. 'Pm2p5 aerosol' means atmospheric particulate compounds with an aerodynamic diameter of less than or equal to 2.5 micrometers.", "dimensions": "longitude latitude time", "out_name": "sfpm25", "type": "real", diff --git a/TestTables/CMIP6_AERmon.json b/TestTables/CMIP6_AERmon.json index 72b148e7..ac7b0464 100644 --- a/TestTables/CMIP6_AERmon.json +++ b/TestTables/CMIP6_AERmon.json @@ -1,10 +1,10 @@ { "Header": { - "data_specs_version": "01.00.21", + "data_specs_version": "01.00.23", + "cmor_version": "3.3", "table_id": "Table AERmon", "realm": "aerosol", - "cmor_version": "3.2", - "table_date": "14 February 2018", + "table_date": "21 March 2018", "missing_value": "1e20", "int_missing_value": "-999", "product": "model-output", @@ -22,8 +22,8 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "ambient aerosol absorption optical thickness at 550 nm", - "comment": "", - "dimensions": "longitude latitude time", + "comment": "alias::atmosphere_absorption_optical_thickness_due_to_ambient_aerosol", + "dimensions": "longitude latitude time lambda550nm", "out_name": "abs550aer", "type": "real", "positive": "", @@ -40,7 +40,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "Vertically integrated mass content of air in layer", - "comment": "", + "comment": "'Mass_of_air' means the mass due solely to the gaseous constituents of the atmosphere. The standard name for the mass including precipitation and aerosol particles is atmosphere_mass_per_unit_area.", "dimensions": "longitude latitude alevel time", "out_name": "airmass", "type": "real", @@ -94,7 +94,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "C2H2 volume mixing ratio", - "comment": "", + "comment": "Mole fraction is used in the construction mole_fraction_of_X_in_Y, where X is a material constituent of Y.", "dimensions": "longitude latitude alevel time", "out_name": "c2h2", "type": "real", @@ -112,7 +112,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "C2H6 volume mixing ratio", - "comment": "", + "comment": "Mole fraction is used in the construction mole_fraction_of_X_in_Y, where X is a material constituent of Y.", "dimensions": "longitude latitude alevel time", "out_name": "c2h6", "type": "real", @@ -130,7 +130,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "C3H6 volume mixing ratio", - "comment": "", + "comment": "Mole fraction is used in the construction mole_fraction_of_X_in_Y, where X is a material constituent of Y.", "dimensions": "longitude latitude alevel time", "out_name": "c3h6", "type": "real", @@ -148,7 +148,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "C3H8 volume mixing ratio", - "comment": "", + "comment": "Mole fraction is used in the construction mole_fraction_of_X_in_Y, where X is a material constituent of Y.", "dimensions": "longitude latitude alevel time", "out_name": "c3h8", "type": "real", @@ -202,7 +202,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "CH3COCH3 volume mixing ratio", - "comment": "", + "comment": "Mole fraction is used in the construction 'mole_fraction_of_X_in_Y', where X is a material constituent of Y. A chemical species denoted by X may be described by a single term such as 'nitrogen' or a phrase such as 'nox_expressed_as_nitrogen'. Acetone is an organic molecule with the chemical formula CH3CH3CO. The IUPAC name for acetone is propan-2-one. Acetone is a member of the group of organic compounds known as ketones. There are standard names for the ketone group as well as for some of the individual species.", "dimensions": "longitude latitude alevel time", "out_name": "ch3coch3", "type": "real", @@ -220,7 +220,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "CH4 volume mixing ratio", - "comment": "", + "comment": "Mole fraction is used in the construction mole_fraction_of_X_in_Y, where X is a material constituent of Y.", "dimensions": "longitude latitude alevel time", "out_name": "ch4", "type": "real", @@ -328,7 +328,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "CO volume mixing ratio", - "comment": "", + "comment": "Mole fraction is used in the construction mole_fraction_of_X_in_Y, where X is a material constituent of Y.", "dimensions": "longitude latitude alevel time", "out_name": "co", "type": "real", @@ -346,7 +346,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "CO2 volume mixing ratio", - "comment": "", + "comment": "Mole fraction is used in the construction mole_fraction_of_X_in_Y, where X is a material constituent of Y.", "dimensions": "longitude latitude alevel time", "out_name": "co2", "type": "real", @@ -364,7 +364,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "cloud optical depth", - "comment": "", + "comment": "The optical thickness is the integral along the path of radiation of a volume scattering/absorption/attenuation coefficient. The radiative flux is reduced by a factor exp(-optical_thickness) on traversing the path. A coordinate variable of radiation_wavelength or radiation_frequency can be specified to indicate that the optical thickness applies at specific wavelengths or frequencies. The atmosphere optical thickness applies to radiation passing through the entire atmosphere. 'Cloud' means the component of extinction owing to the presence of liquid or ice water particles. The specification of a physical process by the phrase due_to_process means that the quantity named is a single term in a sum of terms which together compose the general quantity named by omitting the phrase.", "dimensions": "longitude latitude time", "out_name": "cod", "type": "real", @@ -382,7 +382,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "DMS volume mixing ratio", - "comment": "", + "comment": "Mole fraction is used in the construction mole_fraction_of_X_in_Y, where X is a material constituent of Y.", "dimensions": "longitude latitude alevel time", "out_name": "dms", "type": "real", @@ -904,7 +904,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "Formaldehyde volume mixing ratio", - "comment": "", + "comment": "Mole fraction is used in the construction mole_fraction_of_X_in_Y, where X is a material constituent of Y.", "dimensions": "longitude latitude alevel time", "out_name": "hcho", "type": "real", @@ -922,7 +922,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "HCl volume mixing ratio", - "comment": "", + "comment": "Mole fraction is used in the construction mole_fraction_of_X_in_Y, where X is a material constituent of Y. The chemical formula of hydrogen chloride is HCl.", "dimensions": "longitude latitude alevel time", "out_name": "hcl", "type": "real", @@ -940,7 +940,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "HNO3 volume mixing ratio", - "comment": "", + "comment": "Mole fraction is used in the construction mole_fraction_of_X_in_Y, where X is a material constituent of Y.", "dimensions": "longitude latitude alevel time", "out_name": "hno3", "type": "real", @@ -958,7 +958,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "Isoprene volume mixing ratio", - "comment": "", + "comment": "Mole fraction is used in the construction mole_fraction_of_X_in_Y, where X is a material constituent of Y.", "dimensions": "longitude latitude alevel time", "out_name": "isop", "type": "real", @@ -976,7 +976,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "photolysis rate of NO2", - "comment": "", + "comment": "'Photolysis' is a chemical reaction in which a chemical compound is broken down by photons. The 'reaction rate' is the rate at which the reactants of a chemical reaction form the products. The chemical formula for nitrogen dioxide is NO2.", "dimensions": "longitude latitude alevel time", "out_name": "jno2", "type": "real", @@ -1048,7 +1048,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "liquid water path", - "comment": "", + "comment": "'Content' indicates a quantity per unit area. The 'atmosphere content' of a quantity refers to the vertical integral from the surface to the top of the atmosphere. For the content between specified levels in the atmosphere, standard names including content_of_atmosphere_layer are used.", "dimensions": "longitude latitude time", "out_name": "lwp", "type": "real", @@ -1066,7 +1066,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "Aerosol water mass mixing ratio", - "comment": "", + "comment": "Mass fraction is used in the construction mass_fraction_of_X_in_Y, where X is a material constituent of Y. It means the ratio of the mass of X to the mass of Y (including X). 'Aerosol' means the system of suspended liquid or solid particles in air (except cloud droplets) and their carrier gas, the air itself. 'Ambient_aerosol' means that the aerosol is measured or modelled at the ambient state of pressure, temperature and relative humidity that exists in its immediate environment. 'Ambient aerosol particles' are aerosol particles that have taken up ambient water through hygroscopic growth. The extent of hygroscopic growth depends on the relative humidity and the composition of the particles.", "dimensions": "longitude latitude alevel time", "out_name": "mmraerh2o", "type": "real", @@ -1084,7 +1084,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "Elemental carbon mass mixing ratio", - "comment": "", + "comment": "Mass fraction is used in the construction mass_fraction_of_X_in_Y, where X is a material constituent of Y. It means the ratio of the mass of X to the mass of Y (including X). 'Aerosol' means the system of suspended liquid or solid particles in air (except cloud droplets) and their carrier gas, the air itself. Aerosol takes up ambient water (a process known as hygroscopic growth) depending on the relative humidity and the composition of the aerosol. 'Dry aerosol particles' means aerosol particles without any water uptake. Chemically, 'elemental carbon' is the carbonaceous fraction of particulate matter that is thermally stable in an inert atmosphere to high temperatures near 4000K and can only be gasified by oxidation starting at temperatures above 340 C. It is assumed to be inert and non-volatile under atmospheric conditions and insoluble in any solvent (Ogren and Charlson, 1983).", "dimensions": "longitude latitude alevel time", "out_name": "mmrbc", "type": "real", @@ -1102,7 +1102,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "Dust aerosol mass mixing ratio", - "comment": "", + "comment": "Mass fraction is used in the construction mass_fraction_of_X_in_Y, where X is a material constituent of Y. It means the ratio of the mass of X to the mass of Y (including X). 'Aerosol' means the system of suspended liquid or solid particles in air (except cloud droplets) and their carrier gas, the air itself. Aerosol particles take up ambient water (a process known as hygroscopic growth) depending on the relative humidity and the composition of the particles. 'Dry aerosol particles' means aerosol particles without any water uptake.", "dimensions": "longitude latitude alevel time", "out_name": "mmrdust", "type": "real", @@ -1120,7 +1120,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "NH4 mass mixing ratio", - "comment": "", + "comment": "Mass fraction is used in the construction mass_fraction_of_X_in_Y, where X is a material constituent of Y. It means the ratio of the mass of X to the mass of Y (including X). 'Mass_fraction_of_ammonium' means that the mass is expressed as mass of NH4. 'Aerosol' means the system of suspended liquid or solid particles in air (except cloud droplets) and their carrier gas, the air itself. Aerosol particles take up ambient water (a process known as hygroscopic growth) depending on the relative humidity and the composition of the particles. 'Dry aerosol particles' means aerosol particles without any water uptake.", "dimensions": "longitude latitude alevel time", "out_name": "mmrnh4", "type": "real", @@ -1138,7 +1138,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "NO3 aerosol mass mixing ratio", - "comment": "", + "comment": "Mass fraction is used in the construction mass_fraction_of_X_in_Y, where X is a material constituent of Y. It means the ratio of the mass of X to the mass of Y (including X). 'Mass_fraction_of_nitrate' means that the mass is expressed as mass of NO3. 'Aerosol' means the system of suspended liquid or solid particles in air (except cloud droplets) and their carrier gas, the air itself. Aerosol particles take up ambient water (a process known as hygroscopic growth) depending on the relative humidity and the composition of the particles. 'Dry aerosol particles' means aerosol particles without any water uptake.", "dimensions": "longitude latitude alevel time", "out_name": "mmrno3", "type": "real", @@ -1228,7 +1228,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "Aerosol sulfate mass mixing ratio", - "comment": "", + "comment": "Mass fraction is used in the construction mass_fraction_of_X_in_Y, where X is a material constituent of Y. It means the ratio of the mass of X to the mass of Y (including X). 'Mass_fraction_of_sulfate' means that the mass is expressed as mass of SO4. 'Aerosol' means the system of suspended liquid or solid particles in air (except cloud droplets) and their carrier gas, the air itself. Aerosol particles take up ambient water (a process known as hygroscopic growth) depending on the relative humidity and the composition of the particles. 'Dry aerosol particles' means aerosol particles without any water uptake.", "dimensions": "longitude latitude alevel time", "out_name": "mmrso4", "type": "real", @@ -1246,7 +1246,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "Secondary organic aerosol mass mixing ratio", - "comment": "", + "comment": "Mass fraction is used in the construction mass_fraction_of_X_in_Y, where X is a material constituent of Y. It means the ratio of the mass of X to the mass of Y (including X). 'Aerosol' means the system of suspended liquid or solid particles in air (except cloud droplets) and their carrier gas, the air itself. Aerosol particles take up ambient water (a process known as hygroscopic growth) depending on the relative humidity and the composition of the particles. 'Dry aerosol particles' means aerosol particles without any water uptake. 'Secondary particulate organic matter' means particulate organic matter formed within the atmosphere from gaseous precursors. The sum of primary_particulate_organic_matter_dry_aerosol and secondary_particulate_organic_matter_dry_aerosol is particulate_organic_matter_dry_aerosol.", "dimensions": "longitude latitude alevel time", "out_name": "mmrsoa", "type": "real", @@ -1264,7 +1264,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "Sea Salt mass mixing ratio", - "comment": "", + "comment": "alias::mass_fraction_of_seasalt_dry_aerosol_particles_in_air", "dimensions": "longitude latitude alevel time", "out_name": "mmrss", "type": "real", @@ -1282,7 +1282,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "N2O volume mixing ratio", - "comment": "", + "comment": "Mole fraction is used in the construction mole_fraction_of_X_in_Y, where X is a material constituent of Y. The chemical formula of nitrous oxide is N2O.", "dimensions": "longitude latitude alevel time", "out_name": "n2o", "type": "real", @@ -1300,7 +1300,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "Artificial tracer with 50 day lifetime", - "comment": "", + "comment": "Mole fraction is used in the construction 'mole_fraction_of_X_in_Y', where X is a material constituent of Y. A chemical species denoted by X may be described by a single term such as 'nitrogen' or a phrase such as 'nox_expressed_as_nitrogen'. 'Artificial tracer' means a passive atmospheric tracer that is used to study atmospheric transport and deposition. To specify the length of the tracer lifetime in the atmosphere, a scalar coordinate variable with the standard name of tracer_lifetime should be used.", "dimensions": "longitude latitude alevel time", "out_name": "nh50", "type": "real", @@ -1318,7 +1318,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "NO volume mixing ratio", - "comment": "", + "comment": "Mole fraction is used in the construction mole_fraction_of_X_in_Y, where X is a material constituent of Y.", "dimensions": "longitude latitude alevel time", "out_name": "no", "type": "real", @@ -1336,7 +1336,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "NO2 volume mixing ratio", - "comment": "", + "comment": "Mole fraction is used in the construction mole_fraction_of_X_in_Y, where X is a material constituent of Y.", "dimensions": "longitude latitude alevel time", "out_name": "no2", "type": "real", @@ -1354,7 +1354,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "Ozone volume mixing ratio", - "comment": "", + "comment": "Mole fraction is used in the construction mole_fraction_of_X_in_Y, where X is a material constituent of Y.", "dimensions": "longitude latitude alevel time", "out_name": "o3", "type": "real", @@ -1445,7 +1445,7 @@ "cell_measures": "area: areacella", "long_name": "ambient aerosol optical thickness at 550 nm", "comment": "AOD from the ambient aerosols (i.e., includes aerosol water). Does not include AOD from stratospheric aerosols if these are prescribed but includes other possible background aerosol types. Needs a comment attribute 'wavelength: 550 nm'", - "dimensions": "longitude latitude time", + "dimensions": "longitude latitude time lambda550nm", "out_name": "od550aer", "type": "real", "positive": "", @@ -1463,7 +1463,7 @@ "cell_measures": "area: areacella", "long_name": "aerosol water aod@550nm", "comment": "proposed name: atmosphere_optical_thickness_due_to_water_ambient_aerosol", - "dimensions": "longitude latitude time", + "dimensions": "longitude latitude time lambda550nm", "out_name": "od550aerh2o", "type": "real", "positive": "", @@ -1481,7 +1481,7 @@ "cell_measures": "area: areacella", "long_name": "bb aod@550nm", "comment": "total organic aerosol AOD due to biomass burning (excluding so4, nitrate BB components)", - "dimensions": "longitude latitude time", + "dimensions": "longitude latitude time lambda550nm", "out_name": "od550bb", "type": "real", "positive": "", @@ -1498,8 +1498,8 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "black carbon aod@550nm", - "comment": "", - "dimensions": "longitude latitude time", + "comment": "The specification of a physical process by the phrase due_to_process means that the quantity named is a single term in a sum of terms which together compose the general quantity named by omitting the phrase. The optical thickness is the integral along the path of radiation of a volume scattering/absorption/attenuation coefficient. The radiative flux is reduced by a factor exp(-optical_thickness) on traversing the path. The atmosphere optical thickness applies to radiation passing through the entire atmosphere. 'Aerosol' means the suspended liquid or solid particles in air (except cloud droplets). 'Ambient aerosol' is aerosol that has taken up ambient water through hygroscopic growth. The extent of hygroscopic growth depends on the relative humidity and the composition of the aerosol. Black carbon aerosol is composed of elemental carbon. It is strongly light absorbing.", + "dimensions": "longitude latitude time lambda550nm", "out_name": "od550bc", "type": "real", "positive": "", @@ -1517,7 +1517,7 @@ "cell_measures": "area: areacella", "long_name": "ambient aerosol optical thickness at 550 nm", "comment": "AOD from the ambient aerosols in clear skies if od550aer is for all-sky (i.e., includes aerosol water). Does not include AOD from stratospheric aerosols if these are prescribed but includes other possible background aerosol types. Needs a comment attribute 'wavelength: 550 nm'", - "dimensions": "longitude latitude time", + "dimensions": "longitude latitude time lambda550nm", "out_name": "od550csaer", "type": "real", "positive": "", @@ -1534,8 +1534,8 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "dust aod@550nm", - "comment": "", - "dimensions": "longitude latitude time", + "comment": "alias::atmosphere_optical_thickness_due_to_dust_ambient_aerosol", + "dimensions": "longitude latitude time lambda550nm", "out_name": "od550dust", "type": "real", "positive": "", @@ -1553,7 +1553,7 @@ "cell_measures": "area: areacella", "long_name": "ambient fine mode aerosol optical thickness at 550 nm", "comment": "od550 due to particles with wet diameter less than 1 um (ambient here means wetted). When models do not include explicit size information, it can be assumed that all anthropogenic aerosols and natural secondary aerosols have diameter less than 1 um.", - "dimensions": "longitude latitude time", + "dimensions": "longitude latitude time lambda550nm", "out_name": "od550lt1aer", "type": "real", "positive": "", @@ -1565,13 +1565,13 @@ "od550no3": { "frequency": "mon", "modeling_realm": "aerosol", - "standard_name": "atmosphere_optical_thickness_due_to_nitrate_ambient_aerosol", + "standard_name": "atmosphere_optical_thickness_due_to_nitrate_ambient_aerosol_particles", "units": "1", "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "nitrate aod@550nm", "comment": "proposed name: atmosphere_optical_thickness_due_to_nitrate_ambient_aerosol", - "dimensions": "longitude latitude time", + "dimensions": "longitude latitude time lambda550nm", "out_name": "od550no3", "type": "real", "positive": "", @@ -1588,8 +1588,8 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "total organic aerosol aod@550nm", - "comment": "", - "dimensions": "longitude latitude time", + "comment": "alias::atmosphere_optical_thickness_due_to_particulate_organic_matter_ambient_aerosol", + "dimensions": "longitude latitude time lambda550nm", "out_name": "od550oa", "type": "real", "positive": "", @@ -1601,13 +1601,13 @@ "od550so4": { "frequency": "mon", "modeling_realm": "aerosol", - "standard_name": "atmosphere_optical_thickness_due_to_sulfate_ambient_aerosol", + "standard_name": "atmosphere_optical_thickness_due_to_sulfate_ambient_aerosol_particles", "units": "1", "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "sulfate aod@550nm", "comment": "proposed name: atmosphere_optical_thickness_due_to_sulfate_ambient_aerosol", - "dimensions": "longitude latitude time", + "dimensions": "longitude latitude time lambda550nm", "out_name": "od550so4", "type": "real", "positive": "", @@ -1625,7 +1625,7 @@ "cell_measures": "area: areacella", "long_name": "soa aod@550nm", "comment": "total organic aerosol AOD due to secondary aerosol formation", - "dimensions": "longitude latitude time", + "dimensions": "longitude latitude time lambda550nm", "out_name": "od550soa", "type": "real", "positive": "", @@ -1642,8 +1642,8 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "sea salt aod@550nm", - "comment": "", - "dimensions": "longitude latitude time", + "comment": "alias::atmosphere_optical_thickness_due_to_seasalt_ambient_aerosol", + "dimensions": "longitude latitude time lambda550nm", "out_name": "od550ss", "type": "real", "positive": "", @@ -1678,7 +1678,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "OH volume mixing ratio", - "comment": "", + "comment": "Mole fraction is used in the construction mole_fraction_of_X_in_Y, where X is a material constituent of Y.", "dimensions": "longitude latitude alevel time", "out_name": "oh", "type": "real", @@ -1696,7 +1696,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "PAN volume mixing ratio", - "comment": "", + "comment": "Mole fraction is used in the construction mole_fraction_of_X_in_Y, where X is a material constituent of Y.", "dimensions": "longitude latitude alevel time", "out_name": "pan", "type": "real", @@ -1889,7 +1889,7 @@ "rsutcsaf": { "frequency": "mon", "modeling_realm": "aerosol", - "standard_name": "toa_outgoing_shortwave_flux_assuming_clear_sky", + "standard_name": "toa_outgoing_shortwave_flux_assuming_clean_clear_sky", "units": "W m-2", "cell_methods": "area: time: mean", "cell_measures": "area: areacella", @@ -1912,7 +1912,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "SO2 volume mixing ratio", - "comment": "", + "comment": "Mole fraction is used in the construction mole_fraction_of_X_in_Y, where X is a material constituent of Y.", "dimensions": "longitude latitude alevel time", "out_name": "so2", "type": "real", @@ -2020,7 +2020,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "air temperature at cloud top", - "comment": "", + "comment": "cloud_top refers to the top of the highest cloud. Air temperature is the bulk temperature of the air, not the surface (skin) temperature.", "dimensions": "longitude latitude time", "out_name": "ttop", "type": "real", @@ -2038,7 +2038,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "Eastward Wind", - "comment": "", + "comment": "'Eastward' indicates a vector component which is positive when directed eastward (negative westward). Wind is defined as a two-dimensional (horizontal) air velocity vector, with no vertical component. (Vertical motion in the atmosphere has the standard name upward_air_velocity.)", "dimensions": "longitude latitude alevel time", "out_name": "ua", "type": "real", @@ -2056,7 +2056,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "Northward Wind", - "comment": "", + "comment": "'Northward' indicates a vector component which is positive when directed northward (negative southward). Wind is defined as a two-dimensional (horizontal) air velocity vector, with no vertical component. (Vertical motion in the atmosphere has the standard name upward_air_velocity.)", "dimensions": "longitude latitude alevel time", "out_name": "va", "type": "real", @@ -2074,7 +2074,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "Upward Air Velocity", - "comment": "", + "comment": "A velocity is a vector quantity. 'Upward' indicates a vector component which is positive when directed upward (negative downward). Upward air velocity is the vertical component of the 3D air velocity vector. The standard name downward_air_velocity may be used for a vector component with the opposite sign convention.", "dimensions": "longitude latitude alevel time", "out_name": "wa", "type": "real", @@ -2092,7 +2092,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "wet deposition rate of black carbon aerosol mass", - "comment": "", + "comment": "'tendency_of_X' means derivative of X with respect to time. 'Content' indicates a quantity per unit area. The 'atmosphere content' of a quantity refers to the vertical integral from the surface to the top of the atmosphere. For the content between specified levels in the atmosphere, standard names including 'content_of_atmosphere_layer' are used. The mass is the total mass of the particles. 'Aerosol' means the system of suspended liquid or solid particles in air (except cloud droplets) and their carrier gas, the air itself. Aerosol takes up ambient water (a process known as hygroscopic growth) depending on the relative humidity and the composition of the aerosol. 'Dry aerosol particles' means aerosol particles without any water uptake. The specification of a physical process by the phrase 'due_to_' process means that the quantity named is a single term in a sum of terms which together compose the general quantity named by omitting the phrase. 'Wet deposition' means deposition by precipitation.", "dimensions": "longitude latitude time", "out_name": "wetbc", "type": "real", @@ -2110,7 +2110,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "wet deposition rate of dust", - "comment": "", + "comment": "'Content' indicates a quantity per unit area. The 'atmosphere content' of a quantity refers to the vertical integral from the surface to the top of the atmosphere. For the content between specified levels in the atmosphere, standard names including 'content_of_atmosphere_layer' are used. The mass is the total mass of the particles. 'Aerosol' means the system of suspended liquid or solid particles in air (except cloud droplets) and their carrier gas, the air itself. Aerosol particles take up ambient water (a process known as hygroscopic growth) depending on the relative humidity and the composition of the particles. 'Dry aerosol particles' means aerosol particles without any water uptake. 'Wet deposition' means deposition by precipitation. 'tendency_of_X' means derivative of X with respect to time.", "dimensions": "longitude latitude time", "out_name": "wetdust", "type": "real", @@ -2128,7 +2128,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "wet deposition rate of nh3", - "comment": "", + "comment": "'tendency_of_X' means derivative of X with respect to time. 'Content' indicates a quantity per unit area. 'Wet deposition' means deposition by precipitation.", "dimensions": "longitude latitude time", "out_name": "wetnh3", "type": "real", @@ -2146,7 +2146,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "wet deposition rate of nh4", - "comment": "", + "comment": "'Content' indicates a quantity per unit area. The 'atmosphere content' of a quantity refers to the vertical integral from the surface to the top of the atmosphere. For the content between specified levels in the atmosphere, standard names including content_of_atmosphere_layer are used. The mass is the total mass of the particles. 'Aerosol' means the system of suspended liquid or solid particles in air (except cloud droplets) and their carrier gas, the air itself. Aerosol particles take up ambient water (a process known as hygroscopic growth) depending on the relative humidity and the composition of the particles. 'Dry aerosol particles' means aerosol particles without any water uptake. The specification of a physical process by the phrase due_to_process means that the quantity named is a single term in a sum of terms which together compose the general quantity named by omitting the phrase. 'Wet deposition' means deposition by precipitation. 'tendency_of_X' means derivative of X with respect to time.", "dimensions": "longitude latitude time", "out_name": "wetnh4", "type": "real", @@ -2200,7 +2200,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "wet deposition rate of so2", - "comment": "", + "comment": "'tendency_of_X' means derivative of X with respect to time. 'Content' indicates a quantity per unit area. 'Wet deposition' means deposition by precipitation.", "dimensions": "longitude latitude time", "out_name": "wetso2", "type": "real", @@ -2236,7 +2236,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "wet deposition rate of seasalt", - "comment": "", + "comment": "alias::tendency_of_atmosphere_mass_content_of_seasalt_dry_aerosol_particles_due_to_wet_deposition", "dimensions": "longitude latitude time", "out_name": "wetss", "type": "real", @@ -2254,7 +2254,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "Geopotential Height", - "comment": "", + "comment": "Geopotential is the sum of the specific gravitational potential energy relative to the geoid and the specific centripetal potential energy. Geopotential height is the geopotential divided by the standard acceleration due to gravity. It is numerically similar to the altitude (or geometric height) and not to the quantity with standard name height, which is relative to the surface.", "dimensions": "longitude latitude alevel time", "out_name": "zg", "type": "real", diff --git a/TestTables/CMIP6_AERmonZ.json b/TestTables/CMIP6_AERmonZ.json index 05aae2cf..a1c9e31a 100644 --- a/TestTables/CMIP6_AERmonZ.json +++ b/TestTables/CMIP6_AERmonZ.json @@ -1,10 +1,10 @@ { "Header": { - "data_specs_version": "01.00.21", + "data_specs_version": "01.00.23", + "cmor_version": "3.3", "table_id": "Table AERmonZ", "realm": "aerosol", - "cmor_version": "3.2", - "table_date": "14 February 2018", + "table_date": "21 March 2018", "missing_value": "1e20", "int_missing_value": "-999", "product": "model-output", @@ -40,7 +40,7 @@ "cell_methods": "longitude: mean time: mean", "cell_measures": "", "long_name": "CH4 volume mixing ratio", - "comment": "", + "comment": "Mole fraction is used in the construction mole_fraction_of_X_in_Y, where X is a material constituent of Y.", "dimensions": "latitude plev39 time", "out_name": "ch4", "type": "real", @@ -94,7 +94,7 @@ "cell_methods": "longitude: mean time: mean", "cell_measures": "", "long_name": "HCl volume mixing ratio", - "comment": "", + "comment": "Mole fraction is used in the construction mole_fraction_of_X_in_Y, where X is a material constituent of Y. The chemical formula of hydrogen chloride is HCl.", "dimensions": "latitude plev39 time", "out_name": "hcl", "type": "real", @@ -112,7 +112,7 @@ "cell_methods": "longitude: mean time: mean", "cell_measures": "", "long_name": "HNO3 volume mixing ratio", - "comment": "", + "comment": "Mole fraction is used in the construction mole_fraction_of_X_in_Y, where X is a material constituent of Y.", "dimensions": "latitude plev39 time", "out_name": "hno3", "type": "real", @@ -130,7 +130,7 @@ "cell_methods": "longitude: mean time: mean", "cell_measures": "", "long_name": "HO2 volume mixing ratio", - "comment": "", + "comment": "Mole fraction is used in the construction mole_fraction_of_X_in_Y, where X is a material constituent of Y. The chemical formula of hydroperoxyl radical is HO2.", "dimensions": "latitude plev39 time", "out_name": "ho2", "type": "real", @@ -166,7 +166,7 @@ "cell_methods": "longitude: mean time: mean", "cell_measures": "", "long_name": "N2O volume mixing ratio", - "comment": "", + "comment": "Mole fraction is used in the construction mole_fraction_of_X_in_Y, where X is a material constituent of Y. The chemical formula of nitrous oxide is N2O.", "dimensions": "latitude plev39 time", "out_name": "n2o", "type": "real", @@ -202,7 +202,7 @@ "cell_methods": "longitude: mean time: mean", "cell_measures": "", "long_name": "Ozone volume mixing ratio", - "comment": "", + "comment": "Mole fraction is used in the construction mole_fraction_of_X_in_Y, where X is a material constituent of Y.", "dimensions": "latitude plev39 time", "out_name": "o3", "type": "real", @@ -220,7 +220,7 @@ "cell_methods": "longitude: mean time: mean", "cell_measures": "", "long_name": "OH volume mixing ratio", - "comment": "", + "comment": "Mole fraction is used in the construction mole_fraction_of_X_in_Y, where X is a material constituent of Y.", "dimensions": "latitude plev39 time", "out_name": "oh", "type": "real", @@ -256,7 +256,7 @@ "cell_methods": "longitude: mean time: mean", "cell_measures": "", "long_name": "Eastward Wind", - "comment": "", + "comment": "'Eastward' indicates a vector component which is positive when directed eastward (negative westward). Wind is defined as a two-dimensional (horizontal) air velocity vector, with no vertical component. (Vertical motion in the atmosphere has the standard name upward_air_velocity.)", "dimensions": "latitude plev39 time", "out_name": "ua", "type": "real", @@ -274,7 +274,7 @@ "cell_methods": "longitude: mean time: mean", "cell_measures": "", "long_name": "Northward Wind", - "comment": "", + "comment": "'Northward' indicates a vector component which is positive when directed northward (negative southward). Wind is defined as a two-dimensional (horizontal) air velocity vector, with no vertical component. (Vertical motion in the atmosphere has the standard name upward_air_velocity.)", "dimensions": "latitude plev39 time", "out_name": "va", "type": "real", @@ -310,7 +310,7 @@ "cell_methods": "longitude: mean time: mean", "cell_measures": "", "long_name": "Geopotential Height", - "comment": "", + "comment": "Geopotential is the sum of the specific gravitational potential energy relative to the geoid and the specific centripetal potential energy. Geopotential height is the geopotential divided by the standard acceleration due to gravity. It is numerically similar to the altitude (or geometric height) and not to the quantity with standard name height, which is relative to the surface.", "dimensions": "latitude plev39 time", "out_name": "zg", "type": "real", diff --git a/TestTables/CMIP6_Amon.json b/TestTables/CMIP6_Amon.json index f6d39b4f..e7827864 100644 --- a/TestTables/CMIP6_Amon.json +++ b/TestTables/CMIP6_Amon.json @@ -1,10 +1,10 @@ { "Header": { - "data_specs_version": "01.00.21", + "data_specs_version": "01.00.23", + "cmor_version": "3.3", "table_id": "Table Amon", "realm": "atmos atmosChem", - "cmor_version": "3.2", - "table_date": "14 February 2018", + "table_date": "21 March 2018", "missing_value": "1e20", "int_missing_value": "-999", "product": "model-output", @@ -112,7 +112,7 @@ "cell_methods": "time: mean", "cell_measures": "area: areacella", "long_name": "Mole Fraction of CH4", - "comment": "", + "comment": "Mole fraction is used in the construction mole_fraction_of_X_in_Y, where X is a material constituent of Y.", "dimensions": "longitude latitude plev19 time", "out_name": "ch4", "type": "real", @@ -130,7 +130,7 @@ "cell_methods": "area: mean time: mean within years time: mean over years", "cell_measures": "area: areacella", "long_name": "Mole Fraction of CH4", - "comment": "", + "comment": "Mole fraction is used in the construction mole_fraction_of_X_in_Y, where X is a material constituent of Y.", "dimensions": "longitude latitude plev19 time2", "out_name": "ch4", "type": "real", @@ -310,7 +310,7 @@ "cell_methods": "time: mean", "cell_measures": "area: areacella", "long_name": "Mole Fraction of CO2", - "comment": "", + "comment": "Mole fraction is used in the construction mole_fraction_of_X_in_Y, where X is a material constituent of Y.", "dimensions": "longitude latitude plev19 time", "out_name": "co2", "type": "real", @@ -328,7 +328,7 @@ "cell_methods": "area: mean time: mean within years time: mean over years", "cell_measures": "area: areacella", "long_name": "Mole Fraction of CO2", - "comment": "", + "comment": "Mole fraction is used in the construction mole_fraction_of_X_in_Y, where X is a material constituent of Y.", "dimensions": "longitude latitude plev19 time2", "out_name": "co2", "type": "real", @@ -472,7 +472,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "Surface Upward Latent Heat Flux", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'Upward' indicates a vector component which is positive when directed upward (negative downward). The surface latent heat flux is the exchange of heat between the surface and the air on account of evaporation (including sublimation). In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "longitude latitude time", "out_name": "hfls", "type": "real", @@ -490,7 +490,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "Surface Upward Sensible Heat Flux", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'Upward' indicates a vector component which is positive when directed upward (negative downward). The surface sensible heat flux, also called 'turbulent' heat flux, is the exchange of heat between the surface and the air by motion of air. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics. Unless indicated in the cell_methods attribute, a quantity is assumed to apply to the whole area of each horizontal grid box. Previously, the qualifier where_type was used to specify that the quantity applies only to the part of the grid box of the named type. Names containing the where_type qualifier are deprecated and newly created data should use the cell_methods attribute to indicate the horizontal area to which the quantity applies.", "dimensions": "longitude latitude time", "out_name": "hfss", "type": "real", @@ -544,7 +544,7 @@ "cell_methods": "time: mean", "cell_measures": "area: areacella", "long_name": "Specific Humidity", - "comment": "", + "comment": "'specific' means per unit mass. Specific humidity is the mass fraction of water vapor in (moist) air.", "dimensions": "longitude latitude plev19 time", "out_name": "hus", "type": "real", @@ -598,7 +598,7 @@ "cell_methods": "time: mean", "cell_measures": "area: areacella", "long_name": "Mole Fraction of N2O", - "comment": "", + "comment": "Mole fraction is used in the construction mole_fraction_of_X_in_Y, where X is a material constituent of Y. The chemical formula of nitrous oxide is N2O.", "dimensions": "longitude latitude plev19 time", "out_name": "n2o", "type": "real", @@ -616,7 +616,7 @@ "cell_methods": "area: mean time: mean within years time: mean over years", "cell_measures": "area: areacella", "long_name": "Mole Fraction of N2O", - "comment": "", + "comment": "Mole fraction is used in the construction mole_fraction_of_X_in_Y, where X is a material constituent of Y. The chemical formula of nitrous oxide is N2O.", "dimensions": "longitude latitude plev19 time2", "out_name": "n2o", "type": "real", @@ -670,7 +670,7 @@ "cell_methods": "time: mean", "cell_measures": "area: areacella", "long_name": "Mole Fraction of O3", - "comment": "", + "comment": "Mole fraction is used in the construction mole_fraction_of_X_in_Y, where X is a material constituent of Y.", "dimensions": "longitude latitude plev19 time", "out_name": "o3", "type": "real", @@ -688,7 +688,7 @@ "cell_methods": "area: mean time: mean within years time: mean over years", "cell_measures": "area: areacella", "long_name": "Mole Fraction of O3", - "comment": "", + "comment": "Mole fraction is used in the construction mole_fraction_of_X_in_Y, where X is a material constituent of Y.", "dimensions": "longitude latitude plev19 time2", "out_name": "o3", "type": "real", @@ -850,7 +850,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "Surface Downwelling Longwave Radiation", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'longwave' means longwave radiation. Downwelling radiation is radiation from above. It does not mean 'net downward'. When thought of as being incident on a surface, a radiative flux is sometimes called 'irradiance'. In addition, it is identical with the quantity measured by a cosine-collector light-meter and sometimes called 'vector irradiance'. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "longitude latitude time", "out_name": "rlds", "type": "real", @@ -886,7 +886,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "Surface Upwelling Longwave Radiation", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'longwave' means longwave radiation. Upwelling radiation is radiation from below. It does not mean 'net upward'. When thought of as being incident on a surface, a radiative flux is sometimes called 'irradiance'. In addition, it is identical with the quantity measured by a cosine-collector light-meter and sometimes called 'vector irradiance'. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "longitude latitude time", "out_name": "rlus", "type": "real", @@ -994,7 +994,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "Surface Upwelling Shortwave Radiation", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'shortwave' means shortwave radiation. Upwelling radiation is radiation from below. It does not mean 'net upward'. When thought of as being incident on a surface, a radiative flux is sometimes called 'irradiance'. In addition, it is identical with the quantity measured by a cosine-collector light-meter and sometimes called 'vector irradiance'. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "longitude latitude time", "out_name": "rsus", "type": "real", @@ -1264,7 +1264,7 @@ "cell_methods": "time: mean", "cell_measures": "area: areacella", "long_name": "Eastward Wind", - "comment": "", + "comment": "'Eastward' indicates a vector component which is positive when directed eastward (negative westward). Wind is defined as a two-dimensional (horizontal) air velocity vector, with no vertical component. (Vertical motion in the atmosphere has the standard name upward_air_velocity.)", "dimensions": "longitude latitude plev19 time", "out_name": "ua", "type": "real", @@ -1300,7 +1300,7 @@ "cell_methods": "time: mean", "cell_measures": "area: areacella", "long_name": "Northward Wind", - "comment": "", + "comment": "'Northward' indicates a vector component which is positive when directed northward (negative southward). Wind is defined as a two-dimensional (horizontal) air velocity vector, with no vertical component. (Vertical motion in the atmosphere has the standard name upward_air_velocity.)", "dimensions": "longitude latitude plev19 time", "out_name": "va", "type": "real", @@ -1354,7 +1354,7 @@ "cell_methods": "time: mean", "cell_measures": "area: areacella", "long_name": "Geopotential Height", - "comment": "", + "comment": "Geopotential is the sum of the specific gravitational potential energy relative to the geoid and the specific centripetal potential energy. Geopotential height is the geopotential divided by the standard acceleration due to gravity. It is numerically similar to the altitude (or geometric height) and not to the quantity with standard name height, which is relative to the surface.", "dimensions": "longitude latitude plev19 time", "out_name": "zg", "type": "real", diff --git a/TestTables/CMIP6_CF3hr.json b/TestTables/CMIP6_CF3hr.json index 15e09ff6..0697715d 100644 --- a/TestTables/CMIP6_CF3hr.json +++ b/TestTables/CMIP6_CF3hr.json @@ -1,10 +1,10 @@ { "Header": { - "data_specs_version": "01.00.21", + "data_specs_version": "01.00.23", + "cmor_version": "3.3", "table_id": "Table CF3hr", "realm": "atmos", - "cmor_version": "3.2", - "table_date": "14 February 2018", + "table_date": "21 March 2018", "missing_value": "1e20", "int_missing_value": "-999", "product": "model-output", @@ -346,7 +346,7 @@ "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", "long_name": "Surface Upward Latent Heat Flux", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'Upward' indicates a vector component which is positive when directed upward (negative downward). The surface latent heat flux is the exchange of heat between the surface and the air on account of evaporation (including sublimation). In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "longitude latitude time1", "out_name": "hfls", "type": "real", @@ -364,7 +364,7 @@ "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", "long_name": "Surface Upward Sensible Heat Flux", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'Upward' indicates a vector component which is positive when directed upward (negative downward). The surface sensible heat flux, also called 'turbulent' heat flux, is the exchange of heat between the surface and the air by motion of air. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics. Unless indicated in the cell_methods attribute, a quantity is assumed to apply to the whole area of each horizontal grid box. Previously, the qualifier where_type was used to specify that the quantity applies only to the part of the grid box of the named type. Names containing the where_type qualifier are deprecated and newly created data should use the cell_methods attribute to indicate the horizontal area to which the quantity applies.", "dimensions": "longitude latitude time1", "out_name": "hfss", "type": "real", @@ -778,7 +778,7 @@ "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", "long_name": "Surface Downwelling Longwave Radiation", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'longwave' means longwave radiation. Downwelling radiation is radiation from above. It does not mean 'net downward'. When thought of as being incident on a surface, a radiative flux is sometimes called 'irradiance'. In addition, it is identical with the quantity measured by a cosine-collector light-meter and sometimes called 'vector irradiance'. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "longitude latitude time1", "out_name": "rlds", "type": "real", @@ -814,7 +814,7 @@ "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", "long_name": "Surface Upwelling Longwave Radiation", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'longwave' means longwave radiation. Upwelling radiation is radiation from below. It does not mean 'net upward'. When thought of as being incident on a surface, a radiative flux is sometimes called 'irradiance'. In addition, it is identical with the quantity measured by a cosine-collector light-meter and sometimes called 'vector irradiance'. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "longitude latitude time1", "out_name": "rlus", "type": "real", @@ -922,7 +922,7 @@ "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", "long_name": "Surface Upwelling Shortwave Radiation", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'shortwave' means shortwave radiation. Upwelling radiation is radiation from below. It does not mean 'net upward'. When thought of as being incident on a surface, a radiative flux is sometimes called 'irradiance'. In addition, it is identical with the quantity measured by a cosine-collector light-meter and sometimes called 'vector irradiance'. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "longitude latitude time1", "out_name": "rsus", "type": "real", @@ -1138,7 +1138,7 @@ "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", "long_name": "Altitude of Model Full-Levels", - "comment": "", + "comment": "'Height_above_X' means the vertical distance above the named surface X. A reference ellipsoid is a mathematical figure that approximates the geoid. The geoid is a surface of constant geopotential with which mean sea level would coincide if the ocean were at rest. The ellipsoid is an approximation because the geoid is an irregular shape. A number of reference ellipsoids are defined for use in the field of geodesy. To specify which reference ellipsoid is being used, a grid_mapping variable should be attached to the data variable as described in Chapter 5.6 of the CF Convention.", "dimensions": "longitude latitude alevel time1", "out_name": "zfull", "type": "real", @@ -1156,7 +1156,7 @@ "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", "long_name": "Altitude of Model Half-Levels", - "comment": "", + "comment": "'Height_above_X' means the vertical distance above the named surface X. A reference ellipsoid is a mathematical figure that approximates the geoid. The geoid is a surface of constant geopotential with which mean sea level would coincide if the ocean were at rest. The ellipsoid is an approximation because the geoid is an irregular shape. A number of reference ellipsoids are defined for use in the field of geodesy. To specify which reference ellipsoid is being used, a grid_mapping variable should be attached to the data variable as described in Chapter 5.6 of the CF Convention.", "dimensions": "longitude latitude alevhalf time1", "out_name": "zhalf", "type": "real", diff --git a/TestTables/CMIP6_CFday.json b/TestTables/CMIP6_CFday.json index 3badf94f..b17cf555 100644 --- a/TestTables/CMIP6_CFday.json +++ b/TestTables/CMIP6_CFday.json @@ -1,10 +1,10 @@ { "Header": { - "data_specs_version": "01.00.21", + "data_specs_version": "01.00.23", + "cmor_version": "3.3", "table_id": "Table CFday", "realm": "atmos", - "cmor_version": "3.2", - "table_date": "14 February 2018", + "table_date": "21 March 2018", "missing_value": "1e20", "int_missing_value": "-999", "product": "model-output", @@ -310,7 +310,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "Specific Humidity", - "comment": "", + "comment": "'specific' means per unit mass. Specific humidity is the mass fraction of water vapor in (moist) air.", "dimensions": "longitude latitude alevel time", "out_name": "hus", "type": "real", @@ -580,7 +580,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "Eastward Wind", - "comment": "", + "comment": "'Eastward' indicates a vector component which is positive when directed eastward (negative westward). Wind is defined as a two-dimensional (horizontal) air velocity vector, with no vertical component. (Vertical motion in the atmosphere has the standard name upward_air_velocity.)", "dimensions": "longitude latitude alevel time", "out_name": "ua", "type": "real", @@ -598,7 +598,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "Northward Wind", - "comment": "", + "comment": "'Northward' indicates a vector component which is positive when directed northward (negative southward). Wind is defined as a two-dimensional (horizontal) air velocity vector, with no vertical component. (Vertical motion in the atmosphere has the standard name upward_air_velocity.)", "dimensions": "longitude latitude alevel time", "out_name": "va", "type": "real", @@ -652,7 +652,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "Geopotential Height", - "comment": "", + "comment": "Geopotential is the sum of the specific gravitational potential energy relative to the geoid and the specific centripetal potential energy. Geopotential height is the geopotential divided by the standard acceleration due to gravity. It is numerically similar to the altitude (or geometric height) and not to the quantity with standard name height, which is relative to the surface.", "dimensions": "longitude latitude alevel time", "out_name": "zg", "type": "real", diff --git a/TestTables/CMIP6_CFmon.json b/TestTables/CMIP6_CFmon.json index da74c752..98f06fca 100644 --- a/TestTables/CMIP6_CFmon.json +++ b/TestTables/CMIP6_CFmon.json @@ -1,10 +1,10 @@ { "Header": { - "data_specs_version": "01.00.21", + "data_specs_version": "01.00.23", + "cmor_version": "3.3", "table_id": "Table CFmon", "realm": "atmos", - "cmor_version": "3.2", - "table_date": "14 February 2018", + "table_date": "21 March 2018", "missing_value": "1e20", "int_missing_value": "-999", "product": "model-output", @@ -346,7 +346,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "Specific Humidity", - "comment": "", + "comment": "'specific' means per unit mass. Specific humidity is the mass fraction of water vapor in (moist) air.", "dimensions": "longitude latitude alevel time", "out_name": "hus", "type": "real", diff --git a/TestTables/CMIP6_CFsubhr.json b/TestTables/CMIP6_CFsubhr.json index e9a48086..7426f3e7 100644 --- a/TestTables/CMIP6_CFsubhr.json +++ b/TestTables/CMIP6_CFsubhr.json @@ -1,10 +1,10 @@ { "Header": { - "data_specs_version": "01.00.21", + "data_specs_version": "01.00.23", + "cmor_version": "3.3", "table_id": "Table CFsubhr", "realm": "atmos", - "cmor_version": "3.2", - "table_date": "14 February 2018", + "table_date": "21 March 2018", "missing_value": "1e20", "int_missing_value": "-999", "product": "model-output", @@ -292,7 +292,7 @@ "cell_methods": "area: point time: point", "cell_measures": "", "long_name": "Surface Upward Latent Heat Flux", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'Upward' indicates a vector component which is positive when directed upward (negative downward). The surface latent heat flux is the exchange of heat between the surface and the air on account of evaporation (including sublimation). In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "site time1", "out_name": "hfls", "type": "real", @@ -310,7 +310,7 @@ "cell_methods": "area: point time: point", "cell_measures": "", "long_name": "Surface Upward Sensible Heat Flux", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'Upward' indicates a vector component which is positive when directed upward (negative downward). The surface sensible heat flux, also called 'turbulent' heat flux, is the exchange of heat between the surface and the air by motion of air. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics. Unless indicated in the cell_methods attribute, a quantity is assumed to apply to the whole area of each horizontal grid box. Previously, the qualifier where_type was used to specify that the quantity applies only to the part of the grid box of the named type. Names containing the where_type qualifier are deprecated and newly created data should use the cell_methods attribute to indicate the horizontal area to which the quantity applies.", "dimensions": "site time1", "out_name": "hfss", "type": "real", @@ -364,7 +364,7 @@ "cell_methods": "area: point time: point", "cell_measures": "", "long_name": "Specific Humidity", - "comment": "", + "comment": "'specific' means per unit mass. Specific humidity is the mass fraction of water vapor in (moist) air.", "dimensions": "alevel site time1", "out_name": "hus", "type": "real", @@ -400,7 +400,7 @@ "cell_methods": "area: point", "cell_measures": "", "long_name": "Latitude", - "comment": "", + "comment": "Latitude is positive northward; its units of degree_north (or equivalent) indicate this explicitly. In a latitude-longitude system defined with respect to a rotated North Pole, the standard name of grid_latitude should be used instead of latitude. Grid latitude is positive in the grid-northward direction, but its units should be plain degree.", "dimensions": "site", "out_name": "lat", "type": "real", @@ -418,7 +418,7 @@ "cell_methods": "area: point", "cell_measures": "", "long_name": "Longitude", - "comment": "", + "comment": "Longitude is positive eastward; its units of degree_east (or equivalent) indicate this explicitly. In a latitude-longitude system defined with respect to a rotated North Pole, the standard name of grid_longitude should be used instead of longitude. Grid longitude is positive in the grid-eastward direction, but its units should be plain degree.", "dimensions": "site", "out_name": "lon", "type": "real", @@ -634,7 +634,7 @@ "cell_methods": "area: point time: point", "cell_measures": "", "long_name": "Surface Downwelling Longwave Radiation", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'longwave' means longwave radiation. Downwelling radiation is radiation from above. It does not mean 'net downward'. When thought of as being incident on a surface, a radiative flux is sometimes called 'irradiance'. In addition, it is identical with the quantity measured by a cosine-collector light-meter and sometimes called 'vector irradiance'. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "site time1", "out_name": "rlds", "type": "real", @@ -706,7 +706,7 @@ "cell_methods": "area: point time: point", "cell_measures": "", "long_name": "Surface Upwelling Longwave Radiation", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'longwave' means longwave radiation. Upwelling radiation is radiation from below. It does not mean 'net upward'. When thought of as being incident on a surface, a radiative flux is sometimes called 'irradiance'. In addition, it is identical with the quantity measured by a cosine-collector light-meter and sometimes called 'vector irradiance'. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "site time1", "out_name": "rlus", "type": "real", @@ -886,7 +886,7 @@ "cell_methods": "area: point time: point", "cell_measures": "", "long_name": "Surface Upwelling Shortwave Radiation", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'shortwave' means shortwave radiation. Upwelling radiation is radiation from below. It does not mean 'net upward'. When thought of as being incident on a surface, a radiative flux is sometimes called 'irradiance'. In addition, it is identical with the quantity measured by a cosine-collector light-meter and sometimes called 'vector irradiance'. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "site time1", "out_name": "rsus", "type": "real", @@ -1336,7 +1336,7 @@ "cell_methods": "area: point time: point", "cell_measures": "", "long_name": "Eastward Wind", - "comment": "", + "comment": "'Eastward' indicates a vector component which is positive when directed eastward (negative westward). Wind is defined as a two-dimensional (horizontal) air velocity vector, with no vertical component. (Vertical motion in the atmosphere has the standard name upward_air_velocity.)", "dimensions": "alevel site time1", "out_name": "ua", "type": "real", @@ -1372,7 +1372,7 @@ "cell_methods": "area: point time: point", "cell_measures": "", "long_name": "Northward Wind", - "comment": "", + "comment": "'Northward' indicates a vector component which is positive when directed northward (negative southward). Wind is defined as a two-dimensional (horizontal) air velocity vector, with no vertical component. (Vertical motion in the atmosphere has the standard name upward_air_velocity.)", "dimensions": "alevel site time1", "out_name": "va", "type": "real", @@ -1426,7 +1426,7 @@ "cell_methods": "area: point time: point", "cell_measures": "", "long_name": "Geopotential Height", - "comment": "", + "comment": "Geopotential is the sum of the specific gravitational potential energy relative to the geoid and the specific centripetal potential energy. Geopotential height is the geopotential divided by the standard acceleration due to gravity. It is numerically similar to the altitude (or geometric height) and not to the quantity with standard name height, which is relative to the surface.", "dimensions": "alevel site time1", "out_name": "zg", "type": "real", diff --git a/TestTables/CMIP6_E1hr.json b/TestTables/CMIP6_E1hr.json index e88c53b9..16a72a70 100644 --- a/TestTables/CMIP6_E1hr.json +++ b/TestTables/CMIP6_E1hr.json @@ -1,10 +1,10 @@ { "Header": { - "data_specs_version": "01.00.21", + "data_specs_version": "01.00.23", + "cmor_version": "3.3", "table_id": "Table E1hr", "realm": "atmos", - "cmor_version": "3.2", - "table_date": "14 February 2018", + "table_date": "21 March 2018", "missing_value": "1e20", "int_missing_value": "-999", "product": "model-output", @@ -148,7 +148,7 @@ "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", "long_name": "Eastward Wind", - "comment": "", + "comment": "'Eastward' indicates a vector component which is positive when directed eastward (negative westward). Wind is defined as a two-dimensional (horizontal) air velocity vector, with no vertical component. (Vertical motion in the atmosphere has the standard name upward_air_velocity.)", "dimensions": "longitude latitude plev3 time1", "out_name": "ua", "type": "real", @@ -166,7 +166,7 @@ "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", "long_name": "Eastward Wind", - "comment": "", + "comment": "'Eastward' indicates a vector component which is positive when directed eastward (negative westward). Wind is defined as a two-dimensional (horizontal) air velocity vector, with no vertical component. (Vertical motion in the atmosphere has the standard name upward_air_velocity.)", "dimensions": "longitude latitude plev27 time1", "out_name": "ua", "type": "real", @@ -202,7 +202,7 @@ "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", "long_name": "Northward Wind", - "comment": "", + "comment": "'Northward' indicates a vector component which is positive when directed northward (negative southward). Wind is defined as a two-dimensional (horizontal) air velocity vector, with no vertical component. (Vertical motion in the atmosphere has the standard name upward_air_velocity.)", "dimensions": "longitude latitude plev3 time1", "out_name": "va", "type": "real", @@ -220,7 +220,7 @@ "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", "long_name": "Northward Wind", - "comment": "", + "comment": "'Northward' indicates a vector component which is positive when directed northward (negative southward). Wind is defined as a two-dimensional (horizontal) air velocity vector, with no vertical component. (Vertical motion in the atmosphere has the standard name upward_air_velocity.)", "dimensions": "longitude latitude plev27 time1", "out_name": "va", "type": "real", @@ -292,7 +292,7 @@ "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", "long_name": "Geopotential Height", - "comment": "", + "comment": "Geopotential is the sum of the specific gravitational potential energy relative to the geoid and the specific centripetal potential energy. Geopotential height is the geopotential divided by the standard acceleration due to gravity. It is numerically similar to the altitude (or geometric height) and not to the quantity with standard name height, which is relative to the surface.", "dimensions": "longitude latitude plev27 time1", "out_name": "zg", "type": "real", diff --git a/TestTables/CMIP6_E1hrClimMon.json b/TestTables/CMIP6_E1hrClimMon.json index 9500d33b..f239e850 100644 --- a/TestTables/CMIP6_E1hrClimMon.json +++ b/TestTables/CMIP6_E1hrClimMon.json @@ -1,10 +1,10 @@ { "Header": { - "data_specs_version": "01.00.21", + "data_specs_version": "01.00.23", + "cmor_version": "3.3", "table_id": "Table E1hrClimMon", "realm": "atmos", - "cmor_version": "3.2", - "table_date": "14 February 2018", + "table_date": "21 March 2018", "missing_value": "1e20", "int_missing_value": "-999", "product": "model-output", diff --git a/TestTables/CMIP6_E3hr.json b/TestTables/CMIP6_E3hr.json index 4e8c7ced..891917cb 100644 --- a/TestTables/CMIP6_E3hr.json +++ b/TestTables/CMIP6_E3hr.json @@ -1,10 +1,10 @@ { "Header": { - "data_specs_version": "01.00.21", + "data_specs_version": "01.00.23", + "cmor_version": "3.3", "table_id": "Table E3hr", "realm": "land", - "cmor_version": "3.2", - "table_date": "14 February 2018", + "table_date": "21 March 2018", "missing_value": "1e20", "int_missing_value": "-999", "product": "model-output", @@ -94,7 +94,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "Rainfall Flux", - "comment": "", + "comment": "In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "longitude latitude time", "out_name": "prra", "type": "real", @@ -112,7 +112,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "Convective Rainfall rate", - "comment": "", + "comment": "In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "longitude latitude time", "out_name": "prrc", "type": "real", diff --git a/TestTables/CMIP6_E3hrPt.json b/TestTables/CMIP6_E3hrPt.json index 4b4b6974..1a7cc29e 100644 --- a/TestTables/CMIP6_E3hrPt.json +++ b/TestTables/CMIP6_E3hrPt.json @@ -1,10 +1,10 @@ { "Header": { - "data_specs_version": "01.00.21", + "data_specs_version": "01.00.23", + "cmor_version": "3.3", "table_id": "Table E3hrPt", "realm": "atmos", - "cmor_version": "3.2", - "table_date": "14 February 2018", + "table_date": "21 March 2018", "missing_value": "1e20", "int_missing_value": "-999", "product": "model-output", @@ -17,7 +17,7 @@ "aerasymbnd": { "frequency": "3hrPt", "modeling_realm": "atmos", - "standard_name": "band_aerosol_asymmetry_parameter", + "standard_name": "volume_spectral_asymmetry_factor_in_air_due_to_ambient_aerosol_particles", "units": "1", "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", @@ -40,7 +40,7 @@ "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", "long_name": "Aerosol level extinction optical depth for each band", - "comment": "", + "comment": "The optical thickness is the integral along the path of radiation of a volume scattering/absorption/attenuation coefficient. The radiative flux is reduced by a factor exp(-optical_thickness) on traversing the path. A coordinate variable of radiation_wavelength or radiation_frequency can be specified to indicate that the optical thickness applies at specific wavelengths or frequencies. 'Absorption optical thickness' means that part of the atmosphere optical thickness that is caused by the absorption of incident radiation. 'Aerosol' means the system of suspended liquid or solid particles in air (except cloud droplets) and their carrier gas, the air itself. 'Ambient_aerosol' means that the aerosol is measured or modelled at the ambient state of pressure, temperature and relative humidity that exists in its immediate environment. 'Ambient aerosol particles' are aerosol particles that have taken up ambient water through hygroscopic growth.", "dimensions": "longitude latitude alevel spectband time1", "out_name": "aeroptbnd", "type": "real", @@ -58,7 +58,7 @@ "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", "long_name": "Aerosol level single-scattering albedo for each band", - "comment": "", + "comment": "'Single scattering albedo' is the fraction of radiation in an incident light beam scattered by the particles of an aerosol reference volume for a given wavelength. It is the ratio of the scattering and the extinction coefficients of the aerosol particles in the reference volume. A coordinate variable with a standard name of radiation_wavelength or radiation_frequency should be included to specify either the wavelength or frequency. 'Aerosol' means the system of suspended liquid or solid particles in air (except cloud droplets) and their carrier gas, the air itself. 'Ambient_aerosol' means that the aerosol is measured or modelled at the ambient state of pressure, temperature and relative humidity that exists in its immediate environment. 'Ambient aerosol particles' are aerosol particles that have taken up ambient water through hygroscopic growth. The extent of hygroscopic growth depends on the relative humidity and the composition of the particles.", "dimensions": "longitude latitude alevel spectband time1", "out_name": "aerssabnd", "type": "real", @@ -71,7 +71,7 @@ "albdiffbnd": { "frequency": "3hrPt", "modeling_realm": "atmos", - "standard_name": "band_diffuse_albedo", + "standard_name": "surface_spectral_hemispherical_reflectance_of_diffuse_shortwave_radiation", "units": "1", "cell_methods": "time: point", "cell_measures": "area: areacella", @@ -89,7 +89,7 @@ "albdirbnd": { "frequency": "3hrPt", "modeling_realm": "atmos", - "standard_name": "band_direct_albedo", + "standard_name": "surface_spectral_hemispherical_reflectance_of_direct_shortwave_radiation", "units": "1", "cell_methods": "time: point", "cell_measures": "area: areacella", @@ -148,7 +148,7 @@ "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", "long_name": "CH4 volume mixing ratio", - "comment": "", + "comment": "Mole fraction is used in the construction mole_fraction_of_X_in_Y, where X is a material constituent of Y.", "dimensions": "longitude latitude alevel time1", "out_name": "ch4", "type": "real", @@ -310,7 +310,7 @@ "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", "long_name": "CO2 volume mixing ratio", - "comment": "", + "comment": "Mole fraction is used in the construction mole_fraction_of_X_in_Y, where X is a material constituent of Y.", "dimensions": "longitude latitude alevel time1", "out_name": "co2", "type": "real", @@ -328,7 +328,7 @@ "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", "long_name": "Specific Humidity", - "comment": "", + "comment": "'specific' means per unit mass. Specific humidity is the mass fraction of water vapor in (moist) air.", "dimensions": "longitude latitude alevel time1", "out_name": "hus", "type": "real", @@ -346,7 +346,7 @@ "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", "long_name": "Specific Humidity", - "comment": "", + "comment": "'specific' means per unit mass. Specific humidity is the mass fraction of water vapor in (moist) air.", "dimensions": "longitude latitude plev7h time1", "out_name": "hus", "type": "real", @@ -364,8 +364,8 @@ "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", "long_name": "MODIS Optical Thickness-Particle Size joint distribution, ice", - "comment": "", - "dimensions": "longitude latitude plev7c effectRadIc tau time1", + "comment": "'Layer' means any layer with upper and lower boundaries that have constant values in some vertical coordinate. There must be a vertical coordinate variable indicating the extent of the layer(s). If the layers are model layers, the vertical coordinate can be model_level_number, but it is recommended to specify a physical coordinate (in a scalar or auxiliary coordinate variable) as well. 'X_area_fraction' means the fraction of horizontal area occupied by X. 'X_area' means the horizontal area occupied by X within the grid cell. Cloud area fraction is also called 'cloud amount' and 'cloud cover'.", + "dimensions": "longitude latitude effectRadIc tau time1", "out_name": "jpdftaureicemodis", "type": "real", "positive": "", @@ -382,8 +382,8 @@ "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", "long_name": "MODIS Optical Thickness-Particle Size joint distribution, liquid", - "comment": "", - "dimensions": "longitude latitude plev7c effectRadLi tau time1", + "comment": "'Layer' means any layer with upper and lower boundaries that have constant values in some vertical coordinate. There must be a vertical coordinate variable indicating the extent of the layer(s). If the layers are model layers, the vertical coordinate can be model_level_number, but it is recommended to specify a physical coordinate (in a scalar or auxiliary coordinate variable) as well. 'X_area_fraction' means the fraction of horizontal area occupied by X. 'X_area' means the horizontal area occupied by X within the grid cell. Cloud area fraction is also called 'cloud amount' and 'cloud cover'.", + "dimensions": "longitude latitude effectRadLi tau time1", "out_name": "jpdftaureliqmodis", "type": "real", "positive": "", @@ -400,7 +400,7 @@ "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", "long_name": "N2O volume mixing ratio", - "comment": "", + "comment": "Mole fraction is used in the construction mole_fraction_of_X_in_Y, where X is a material constituent of Y. The chemical formula of nitrous oxide is N2O.", "dimensions": "longitude latitude alevel time1", "out_name": "n2o", "type": "real", @@ -418,7 +418,7 @@ "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", "long_name": "Ozone volume mixing ratio", - "comment": "", + "comment": "Mole fraction is used in the construction mole_fraction_of_X_in_Y, where X is a material constituent of Y.", "dimensions": "longitude latitude alevel time1", "out_name": "o3", "type": "real", @@ -485,7 +485,7 @@ "rsdcsaf": { "frequency": "3hrPt", "modeling_realm": "aerosol", - "standard_name": "downwelling_shortwave_flux_assuming_clean_clear_sky", + "standard_name": "downwelling_shortwave_flux_in_air_assuming_clean_clear_sky", "units": "W m-2", "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", @@ -503,7 +503,7 @@ "rsdcsafbnd": { "frequency": "3hrPt", "modeling_realm": "aerosol", - "standard_name": "band_downwelling_shortwave_flux_assuming_clean_clear_sky", + "standard_name": "downwelling_shortwave_flux_in_air_assuming_clean_clear_sky", "units": "W m-2", "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", @@ -611,7 +611,7 @@ "rsucsaf": { "frequency": "3hrPt", "modeling_realm": "aerosol", - "standard_name": "upwelling_shortwave_flux_assuming_clean_clear_sky", + "standard_name": "upwelling_shortwave_flux_in_air_assuming_clean_clear_sky", "units": "W m-2", "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", @@ -629,7 +629,7 @@ "rsucsafbnd": { "frequency": "3hrPt", "modeling_realm": "aerosol", - "standard_name": "band_upwelling_shortwave_flux_assuming_clean_clear_sky", + "standard_name": "upwelling_shortwave_flux_in_air_assuming_clean_clear_sky", "units": "W m-2", "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", @@ -719,7 +719,7 @@ "rsutcsaf": { "frequency": "3hrPt", "modeling_realm": "aerosol", - "standard_name": "toa_outgoing_shortwave_flux_assuming_clear_sky", + "standard_name": "toa_outgoing_shortwave_flux_assuming_clean_clear_sky", "units": "W m-2", "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", @@ -737,7 +737,7 @@ "rsutcsafbnd": { "frequency": "3hrPt", "modeling_realm": "atmos", - "standard_name": "band_toa_outgoing_shortwave_flux_assuming_clean_clear_sky", + "standard_name": "toa_outgoing_shortwave_flux_assuming_clean_clear_sky", "units": "W m-2", "cell_methods": "time: point", "cell_measures": "area: areacella", @@ -773,7 +773,7 @@ "solbnd": { "frequency": "3hrPt", "modeling_realm": "atmos", - "standard_name": "solar_irradiance", + "standard_name": "toa_incoming_shortwave_flux", "units": "W m-2", "cell_methods": "time: point", "cell_measures": "area: areacella", @@ -832,7 +832,7 @@ "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", "long_name": "Eastward Wind", - "comment": "", + "comment": "'Eastward' indicates a vector component which is positive when directed eastward (negative westward). Wind is defined as a two-dimensional (horizontal) air velocity vector, with no vertical component. (Vertical motion in the atmosphere has the standard name upward_air_velocity.)", "dimensions": "longitude latitude plev7h time1", "out_name": "ua", "type": "real", @@ -850,7 +850,7 @@ "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", "long_name": "Northward Wind", - "comment": "", + "comment": "'Northward' indicates a vector component which is positive when directed northward (negative southward). Wind is defined as a two-dimensional (horizontal) air velocity vector, with no vertical component. (Vertical motion in the atmosphere has the standard name upward_air_velocity.)", "dimensions": "longitude latitude plev7h time1", "out_name": "va", "type": "real", diff --git a/TestTables/CMIP6_E6hrZ.json b/TestTables/CMIP6_E6hrZ.json index 2caab197..9d0fbb9c 100644 --- a/TestTables/CMIP6_E6hrZ.json +++ b/TestTables/CMIP6_E6hrZ.json @@ -1,10 +1,10 @@ { "Header": { - "data_specs_version": "01.00.21", + "data_specs_version": "01.00.23", + "cmor_version": "3.3", "table_id": "Table E6hrZ", "realm": "atmos", - "cmor_version": "3.2", - "table_date": "14 February 2018", + "table_date": "21 March 2018", "missing_value": "1e20", "int_missing_value": "-999", "product": "model-output", diff --git a/TestTables/CMIP6_Eday.json b/TestTables/CMIP6_Eday.json index 08784065..f15f63cd 100644 --- a/TestTables/CMIP6_Eday.json +++ b/TestTables/CMIP6_Eday.json @@ -1,10 +1,10 @@ { "Header": { - "data_specs_version": "01.00.21", + "data_specs_version": "01.00.23", + "cmor_version": "3.3", "table_id": "Table Eday", "realm": "land", - "cmor_version": "3.2", - "table_date": "14 February 2018", + "table_date": "21 March 2018", "missing_value": "1e20", "int_missing_value": "-999", "product": "model-output", @@ -71,13 +71,13 @@ "aod550volso4": { "frequency": "day", "modeling_realm": "atmos", - "standard_name": "aerosol_optical_depth_due_to_stratospheric_volcanic_aerosols", + "standard_name": "stratosphere_optical_thickness_due_to_volcanic_aerosol_particles", "units": "1e-09", "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "Aerosol optical depth at 550 nm due to stratospheric volcanic aerosols", "comment": "aerosol optical depth at 550 nm due to stratospheric volcanic aerosols", - "dimensions": "longitude latitude time", + "dimensions": "longitude latitude time lambda550nm", "out_name": "aod550volso4", "type": "real", "positive": "", @@ -94,7 +94,7 @@ "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacella", "long_name": "Aerodynamic resistance", - "comment": "", + "comment": "The 'aerodynamic_resistance' is the resistance to mixing through the boundary layer toward the surface by means of the dominant process, turbulent transport. Reference: Wesely, M. L., 1989, doi:10.1016/0004-6981(89)90153-4.", "dimensions": "longitude latitude time", "out_name": "ares", "type": "real", @@ -107,7 +107,7 @@ "ccldncl": { "frequency": "day", "modeling_realm": "atmos", - "standard_name": "number_concentration_of_convective_cloud_liquid_water_particles_in_air_at_liquid_water_cloud_top", + "standard_name": "number_concentration_of_convective_cloud_liquid_water_particle_at_convective_liquid_water_cloud_top", "units": "m-3", "cell_methods": "area: time: mean", "cell_measures": "area: areacella", @@ -161,7 +161,7 @@ "clivic": { "frequency": "day", "modeling_realm": "atmos", - "standard_name": "atmosphere_convective_cloud_ice_content", + "standard_name": "atmosphere_mass_content_of_convective_cloud_ice", "units": "kg m-2", "cell_methods": "area: time: mean", "cell_measures": "area: areacella", @@ -220,7 +220,7 @@ "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacella", "long_name": "Canopy covered area percentage", - "comment": "", + "comment": "'X_area_fraction' means the fraction of horizontal area occupied by X. 'X_area' means the horizontal area occupied by X within the grid cell. 'Vegetation' means any plants e.g. trees, shrubs, grass.", "dimensions": "longitude latitude time", "out_name": "cnc", "type": "real", @@ -238,7 +238,7 @@ "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacella", "long_name": "Total Canopy Water Storage", - "comment": "", + "comment": "'Amount' means mass per unit area. 'Water' means water in all phases, including frozen i.e. ice and snow. 'Canopy' means the plant or vegetation canopy. The canopy water is the water on the canopy.", "dimensions": "longitude latitude time", "out_name": "cw", "type": "real", @@ -544,7 +544,7 @@ "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacella", "long_name": "Downward Heat Flux at Land Surface", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'Downward' indicates a vector component which is positive when directed downward (negative upward). The vertical heat flux in air is the sum of all heat fluxes i.e. radiative, latent and sensible. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "longitude latitude time", "out_name": "hfdsl", "type": "real", @@ -575,7 +575,7 @@ "hfdsnb": { "frequency": "day", "modeling_realm": "atmos", - "standard_name": "missing", + "standard_name": "downward_heat_flux_at_ground_level_in_snow", "units": "W m-2", "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacella", @@ -598,7 +598,7 @@ "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacella", "long_name": "Surface Upward Latent Heat Flux", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'Upward' indicates a vector component which is positive when directed upward (negative downward). The surface latent heat flux is the exchange of heat between the surface and the air on account of evaporation (including sublimation). In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "longitude latitude time", "out_name": "hfls", "type": "real", @@ -670,7 +670,7 @@ "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacella", "long_name": "Surface Upward Sensible Heat Flux", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'Upward' indicates a vector component which is positive when directed upward (negative downward). The surface sensible heat flux, also called 'turbulent' heat flux, is the exchange of heat between the surface and the air by motion of air. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics. Unless indicated in the cell_methods attribute, a quantity is assumed to apply to the whole area of each horizontal grid box. Previously, the qualifier where_type was used to specify that the quantity applies only to the part of the grid box of the named type. Names containing the where_type qualifier are deprecated and newly created data should use the cell_methods attribute to indicate the horizontal area to which the quantity applies.", "dimensions": "longitude latitude time", "out_name": "hfss", "type": "real", @@ -706,7 +706,7 @@ "cell_methods": "time: mean", "cell_measures": "area: areacella", "long_name": "Specific Humidity", - "comment": "", + "comment": "'specific' means per unit mass. Specific humidity is the mass fraction of water vapor in (moist) air.", "dimensions": "longitude latitude plev19 time", "out_name": "hus", "type": "real", @@ -742,8 +742,8 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "MODIS Optical Thickness-Particle Size joint distribution, ice", - "comment": "", - "dimensions": "longitude latitude plev7c effectRadIc tau time", + "comment": "'Layer' means any layer with upper and lower boundaries that have constant values in some vertical coordinate. There must be a vertical coordinate variable indicating the extent of the layer(s). If the layers are model layers, the vertical coordinate can be model_level_number, but it is recommended to specify a physical coordinate (in a scalar or auxiliary coordinate variable) as well. 'X_area_fraction' means the fraction of horizontal area occupied by X. 'X_area' means the horizontal area occupied by X within the grid cell. Cloud area fraction is also called 'cloud amount' and 'cloud cover'.", + "dimensions": "longitude latitude effectRadIc tau time", "out_name": "jpdftaureicemodis", "type": "real", "positive": "", @@ -760,8 +760,8 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "MODIS Optical Thickness-Particle Size joint distribution, liquid", - "comment": "", - "dimensions": "longitude latitude plev7c effectRadLi tau time", + "comment": "'Layer' means any layer with upper and lower boundaries that have constant values in some vertical coordinate. There must be a vertical coordinate variable indicating the extent of the layer(s). If the layers are model layers, the vertical coordinate can be model_level_number, but it is recommended to specify a physical coordinate (in a scalar or auxiliary coordinate variable) as well. 'X_area_fraction' means the fraction of horizontal area occupied by X. 'X_area' means the horizontal area occupied by X within the grid cell. Cloud area fraction is also called 'cloud amount' and 'cloud cover'.", + "dimensions": "longitude latitude effectRadLi tau time", "out_name": "jpdftaureliqmodis", "type": "real", "positive": "", @@ -778,7 +778,7 @@ "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacella", "long_name": "Leaf Area Index", - "comment": "", + "comment": "'X_area' means the horizontal area occupied by X within the grid cell.", "dimensions": "longitude latitude time", "out_name": "lai", "type": "real", @@ -973,8 +973,8 @@ "modeling_realm": "ocean", "standard_name": "ocean_mixed_layer_thickness_defined_by_sigma_t", "units": "m", - "cell_methods": "area: time: mean", - "cell_measures": "area: areacella", + "cell_methods": "area: mean where sea time: mean", + "cell_measures": "area: areacello", "long_name": "Ocean Mixed Layer Thickness Defined by Sigma T", "comment": "Sigma T is potential density referenced to ocean surface.", "dimensions": "longitude latitude time", @@ -1030,7 +1030,7 @@ "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacella", "long_name": "Subsurface runoff", - "comment": "", + "comment": "Runoff is the liquid water which drains from land. If not specified, 'runoff' refers to the sum of surface runoff and subsurface drainage. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "longitude latitude time", "out_name": "mrrob", "type": "real", @@ -1061,7 +1061,7 @@ "mrsfl": { "frequency": "day", "modeling_realm": "land", - "standard_name": "frozen_moisture_content_of_soil_layer", + "standard_name": "frozen_water_content_of_soil_layer", "units": "kg m-2", "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacella", @@ -1079,7 +1079,7 @@ "mrsll": { "frequency": "day", "modeling_realm": "land", - "standard_name": "liquid_moisture_content_of_soil_layer", + "standard_name": "liquid_water_content_of_soil_layer", "units": "kg m-2", "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacella", @@ -1246,7 +1246,7 @@ "cell_methods": "area: mean time: mean within hours time: maximum over hours", "cell_measures": "area: areacella", "long_name": "Maximum Hourly Precipitation Rate", - "comment": "", + "comment": "In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "longitude latitude time", "out_name": "prhmax", "type": "real", @@ -1264,7 +1264,7 @@ "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacella", "long_name": "Rainfall Flux over Land", - "comment": "", + "comment": "In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "longitude latitude time", "out_name": "prra", "type": "real", @@ -1282,7 +1282,7 @@ "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacella", "long_name": "Convective Rainfall rate", - "comment": "", + "comment": "In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "longitude latitude time", "out_name": "prrc", "type": "real", @@ -1403,7 +1403,7 @@ "reffcclwtop": { "frequency": "day", "modeling_realm": "atmos", - "standard_name": "effective_radius_of_convective_cloud_liquid_water_particle_at_liquid_water_cloud_top", + "standard_name": "effective_radius_of_convective_cloud_liquid_water_particle_at_convective_liquid_water_cloud_top", "units": "m", "cell_methods": "area: time: mean", "cell_measures": "area: areacella", @@ -1421,7 +1421,7 @@ "reffsclwtop": { "frequency": "day", "modeling_realm": "atmos", - "standard_name": "effective_radius_of_stratiform_cloud_liquid_water_particle_at_liquid_water_cloud_top", + "standard_name": "effective_radius_of_stratiform_cloud_liquid_water_particle_at_stratiform_liquid_water_cloud_top", "units": "m", "cell_methods": "area: time: mean", "cell_measures": "area: areacella", @@ -1484,7 +1484,7 @@ "dimensions": "longitude latitude time", "out_name": "rls", "type": "real", - "positive": "up", + "positive": "down", "valid_min": "", "valid_max": "", "ok_min_mean_abs": "", @@ -1601,7 +1601,7 @@ "scldncl": { "frequency": "day", "modeling_realm": "atmos", - "standard_name": "number_concentration_of_stratiform_cloud_liquid_water_particles_in_air_at_liquid_water_cloud_top", + "standard_name": "number_concentration_of_stratiform_cloud_liquid_water_particle_at_stratiform_liquid_water_cloud_top", "units": "m-3", "cell_methods": "area: time: mean", "cell_measures": "area: areacella", @@ -1678,7 +1678,7 @@ "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacella", "long_name": "Re-freezing of water in the snow", - "comment": "", + "comment": "In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics. The surface called 'surface' means the lower boundary of the atmosphere. 'Surface snow and ice refreezing flux' means the mass flux of surface meltwater which refreezes within the snow or firn.", "dimensions": "longitude latitude time", "out_name": "snrefr", "type": "real", @@ -1747,8 +1747,8 @@ "modeling_realm": "ocean", "standard_name": "depth_of_isosurface_of_sea_water_potential_temperature", "units": "m", - "cell_methods": "area: time: mean", - "cell_measures": "area: areacella", + "cell_methods": "area: mean where sea time: mean", + "cell_measures": "area: areacello", "long_name": "20C isotherm depth", "comment": "", "dimensions": "longitude latitude time", @@ -2102,17 +2102,17 @@ "ok_min_mean_abs": "", "ok_max_mean_abs": "" }, - "tsnl": { + "tsn": { "frequency": "day", - "modeling_realm": "land", - "standard_name": "snow_temperature", + "modeling_realm": "landIce land", + "standard_name": "temperature_in_surface_snow", "units": "K", - "cell_methods": "area: mean where land time: mean", + "cell_methods": "area: mean where land time: mean (with samples weighted by snow mass)", "cell_measures": "area: areacella", - "long_name": "Temperature profile in the snow", - "comment": "Temperature in the snow pack present in the grid-cell. 3D variable for multi-layer snow schemes.", - "dimensions": "longitude latitude snowdepth time", - "out_name": "tsnl", + "long_name": "Snow Internal Temperature", + "comment": "This temperature is averaged over all the snow in the grid cell that rests on land or land ice. When computing the time-mean here, the time samples, weighted by the mass of snow on the land portion of the grid cell, are accumulated and then divided by the sum of the weights. Reported as missing in regions free of snow on land.", + "dimensions": "longitude latitude time", + "out_name": "tsn", "type": "real", "positive": "", "valid_min": "", @@ -2146,7 +2146,7 @@ "cell_methods": "time: mean", "cell_measures": "area: areacella", "long_name": "Eastward Wind", - "comment": "", + "comment": "'Eastward' indicates a vector component which is positive when directed eastward (negative westward). Wind is defined as a two-dimensional (horizontal) air velocity vector, with no vertical component. (Vertical motion in the atmosphere has the standard name upward_air_velocity.)", "dimensions": "longitude latitude plev19 time", "out_name": "ua", "type": "real", @@ -2164,7 +2164,7 @@ "cell_methods": "time: mean", "cell_measures": "area: areacella", "long_name": "Northward Wind", - "comment": "", + "comment": "'Northward' indicates a vector component which is positive when directed northward (negative southward). Wind is defined as a two-dimensional (horizontal) air velocity vector, with no vertical component. (Vertical motion in the atmosphere has the standard name upward_air_velocity.)", "dimensions": "longitude latitude plev19 time", "out_name": "va", "type": "real", @@ -2195,12 +2195,12 @@ "wtd": { "frequency": "day", "modeling_realm": "land", - "standard_name": "depth_of_soil_moisture_saturation", + "standard_name": "water_table_depth", "units": "m", "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacellr", "long_name": "Water table depth", - "comment": "", + "comment": "Depth is the vertical distance below the surface. The water table is the surface below which the soil is saturated with water such that all pore spaces are filled.", "dimensions": "longitude latitude time", "out_name": "wtd", "type": "real", @@ -2218,7 +2218,7 @@ "cell_methods": "time: mean", "cell_measures": "area: areacella", "long_name": "Geopotential Height", - "comment": "", + "comment": "Geopotential is the sum of the specific gravitational potential energy relative to the geoid and the specific centripetal potential energy. Geopotential height is the geopotential divided by the standard acceleration due to gravity. It is numerically similar to the altitude (or geometric height) and not to the quantity with standard name height, which is relative to the surface.", "dimensions": "longitude latitude plev19 time", "out_name": "zg", "type": "real", @@ -2236,7 +2236,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "Height of Boundary Layer", - "comment": "", + "comment": "The atmosphere boundary layer thickness is the 'depth' or 'height' of the (atmosphere) planetary boundary layer.", "dimensions": "longitude latitude time", "out_name": "zmla", "type": "real", diff --git a/TestTables/CMIP6_EdayZ.json b/TestTables/CMIP6_EdayZ.json index 8e63a737..5fe8f6f4 100644 --- a/TestTables/CMIP6_EdayZ.json +++ b/TestTables/CMIP6_EdayZ.json @@ -1,10 +1,10 @@ { "Header": { - "data_specs_version": "01.00.21", + "data_specs_version": "01.00.23", + "cmor_version": "3.3", "table_id": "Table EdayZ", "realm": "atmos", - "cmor_version": "3.2", - "table_date": "14 February 2018", + "table_date": "21 March 2018", "missing_value": "1e20", "int_missing_value": "-999", "product": "model-output", @@ -58,7 +58,7 @@ "cell_methods": "longitude: mean time: mean", "cell_measures": "", "long_name": "Specific Humidity", - "comment": "", + "comment": "'specific' means per unit mass. Specific humidity is the mass fraction of water vapor in (moist) air.", "dimensions": "latitude plev19 time", "out_name": "hus", "type": "real", @@ -72,7 +72,7 @@ "frequency": "day", "modeling_realm": "atmos", "standard_name": "meridional_streamfunction_transformed_eulerian_mean", - "units": "kg s^-1", + "units": "kg s-1", "cell_methods": "longitude: mean time: mean", "cell_measures": "", "long_name": "Transformed Eulerian Mean mass stramfunction", @@ -112,7 +112,7 @@ "cell_methods": "longitude: mean time: mean", "cell_measures": "", "long_name": "Eastward Wind", - "comment": "", + "comment": "'Eastward' indicates a vector component which is positive when directed eastward (negative westward). Wind is defined as a two-dimensional (horizontal) air velocity vector, with no vertical component. (Vertical motion in the atmosphere has the standard name upward_air_velocity.)", "dimensions": "latitude plev39 time", "out_name": "ua", "type": "real", @@ -179,7 +179,7 @@ "utendvtem": { "frequency": "day", "modeling_realm": "atmos", - "standard_name": "u-tendency_by_wstar_advection", + "standard_name": "tendency_of_eastward_wind_due_to_advection_by_the_northward_transformed_eulerian_mean_air_velocity", "units": "m s-1 d-1", "cell_methods": "longitude: mean time: mean", "cell_measures": "", @@ -197,7 +197,7 @@ "utendwtem": { "frequency": "day", "modeling_realm": "atmos", - "standard_name": "u-tendency_by_vstar_advection", + "standard_name": "tendency_of_eastward_wind_due_to_advection_by_the_upward_transformed_eulerian_mean_air_velocity", "units": "m s-1 d-1", "cell_methods": "longitude: mean time: mean", "cell_measures": "", @@ -220,7 +220,7 @@ "cell_methods": "longitude: mean time: mean", "cell_measures": "", "long_name": "Northward Wind", - "comment": "", + "comment": "'Northward' indicates a vector component which is positive when directed northward (negative southward). Wind is defined as a two-dimensional (horizontal) air velocity vector, with no vertical component. (Vertical motion in the atmosphere has the standard name upward_air_velocity.)", "dimensions": "latitude plev19 time", "out_name": "va", "type": "real", @@ -251,7 +251,7 @@ "wtem": { "frequency": "day", "modeling_realm": "atmos", - "standard_name": "unset", + "standard_name": "upward_transformed_eulerian_mean_air_velocity", "units": "m s-1", "cell_methods": "longitude: mean time: mean", "cell_measures": "", @@ -274,7 +274,7 @@ "cell_methods": "longitude: mean time: mean", "cell_measures": "", "long_name": "Geopotential Height", - "comment": "", + "comment": "Geopotential is the sum of the specific gravitational potential energy relative to the geoid and the specific centripetal potential energy. Geopotential height is the geopotential divided by the standard acceleration due to gravity. It is numerically similar to the altitude (or geometric height) and not to the quantity with standard name height, which is relative to the surface.", "dimensions": "latitude plev19 time", "out_name": "zg", "type": "real", diff --git a/TestTables/CMIP6_Efx.json b/TestTables/CMIP6_Efx.json index fe979c6b..1fe2e7db 100644 --- a/TestTables/CMIP6_Efx.json +++ b/TestTables/CMIP6_Efx.json @@ -1,10 +1,10 @@ { "Header": { - "data_specs_version": "01.00.21", + "data_specs_version": "01.00.23", + "cmor_version": "3.3", "table_id": "Table Efx", "realm": "land", - "cmor_version": "3.2", - "table_date": "14 February 2018", + "table_date": "21 March 2018", "missing_value": "1e20", "int_missing_value": "-999", "product": "model-output", @@ -22,7 +22,7 @@ "cell_methods": "area: mean where land", "cell_measures": "area: areacella", "long_name": "Clay Fraction", - "comment": "", + "comment": "'Volume fraction' is used in the construction volume_fraction_of_X_in_Y, where X is a material constituent of Y.", "dimensions": "longitude latitude sdepth", "out_name": "clayfrac", "type": "real", @@ -35,12 +35,12 @@ "fldcapacity": { "frequency": "fx", "modeling_realm": "land", - "standard_name": "missing", + "standard_name": "volume_fraction_of_condensed_water_in_soil_at_field_capacity", "units": "%", "cell_methods": "area: mean where land", "cell_measures": "area: areacella", "long_name": "Field Capacity", - "comment": "", + "comment": "'Condensed water' means liquid and ice. 'Volume fraction' is used in the construction volume_fraction_of_X_in_Y, where X is a material constituent of Y. The field capacity of soil is the maximum content of water it can retain against gravitational drainage.", "dimensions": "longitude latitude sdepth", "out_name": "fldcapacity", "type": "real", @@ -53,12 +53,12 @@ "ksat": { "frequency": "fx", "modeling_realm": "land", - "standard_name": "missing", + "standard_name": "soil_hydraulic_conductivity_at_saturation", "units": "1e-6 m s-1", "cell_methods": "area: mean where land", "cell_measures": "area: areacella", "long_name": "Saturated Hydraulic Conductivity", - "comment": "", + "comment": "Hydraulic conductivity is the constant k in Darcy's Law q=-k grad h for fluid flow q (volume transport per unit area i.e. velocity) through a porous medium, where h is the hydraulic head (pressure expressed as an equivalent depth of water).", "dimensions": "longitude latitude sdepth", "out_name": "ksat", "type": "real", @@ -125,7 +125,7 @@ "rootdsl": { "frequency": "fx", "modeling_realm": "land", - "standard_name": "missing", + "standard_name": "root_mass_content", "units": "kg m-3", "cell_methods": "area: mean where land", "cell_measures": "area: areacella", @@ -179,12 +179,12 @@ "sandfrac": { "frequency": "fx", "modeling_realm": "land", - "standard_name": "missing", + "standard_name": "volume_fraction_of_sand_in_soil", "units": "1", "cell_methods": "area: mean where land", "cell_measures": "area: areacella", "long_name": "Sand Fraction", - "comment": "", + "comment": "'Volume fraction' is used in the construction volume_fraction_of_X_in_Y, where X is a material constituent of Y.", "dimensions": "longitude latitude sdepth", "out_name": "sandfrac", "type": "real", @@ -233,12 +233,12 @@ "siltfrac": { "frequency": "fx", "modeling_realm": "atmos", - "standard_name": "missing", + "standard_name": "volume_fraction_of_silt_in_soil", "units": "1", "cell_methods": "area: mean where land", "cell_measures": "area: areacella", "long_name": "Silt Fraction", - "comment": "", + "comment": "'Volume fraction' is used in the construction volume_fraction_of_X_in_Y, where X is a material constituent of Y.", "dimensions": "longitude latitude sdepth", "out_name": "siltfrac", "type": "real", @@ -251,12 +251,12 @@ "slthick": { "frequency": "fx", "modeling_realm": "land", - "standard_name": "missing", + "standard_name": "cell_thickness", "units": "m", "cell_methods": "area: mean where land", "cell_measures": "area: areacella", "long_name": "Thickness of Soil Layers", - "comment": "", + "comment": "'Thickness' means the vertical extent of a layer. 'Cell' refers to a model grid-cell.", "dimensions": "longitude latitude sdepth", "out_name": "slthick", "type": "real", @@ -274,7 +274,7 @@ "cell_methods": "area: mean where land", "cell_measures": "area: areacella", "long_name": "canopy height", - "comment": "", + "comment": "Height is the vertical distance above the surface. 'Canopy' means the plant or vegetation canopy.", "dimensions": "longitude latitude", "out_name": "vegHeight", "type": "real", @@ -287,12 +287,12 @@ "wilt": { "frequency": "fx", "modeling_realm": "land", - "standard_name": "missing", + "standard_name": "volume_fraction_of_condensed_water_in_soil_at_wilting_point", "units": "%", "cell_methods": "area: mean where land", "cell_measures": "area: areacella", "long_name": "Wilting Point", - "comment": "", + "comment": "'Condensed water' means liquid and ice. 'Volume fraction' is used in the construction volume_fraction_of_X_in_Y, where X is a material constituent of Y. The wilting point of soil is the water content below which plants cannot extract sufficient water to balance their loss through transpiration.", "dimensions": "longitude latitude sdepth", "out_name": "wilt", "type": "real", diff --git a/TestTables/CMIP6_Emon.json b/TestTables/CMIP6_Emon.json index 0d58deb3..348d479d 100644 --- a/TestTables/CMIP6_Emon.json +++ b/TestTables/CMIP6_Emon.json @@ -1,10 +1,10 @@ { "Header": { - "data_specs_version": "01.00.21", + "data_specs_version": "01.00.23", + "cmor_version": "3.3", "table_id": "Table Emon", "realm": "atmos", - "cmor_version": "3.2", - "table_date": "14 February 2018", + "table_date": "21 March 2018", "missing_value": "1e20", "int_missing_value": "-999", "product": "model-output", @@ -197,12 +197,12 @@ "c13Land": { "frequency": "mon", "modeling_realm": "land", - "standard_name": "total_land_c13", + "standard_name": "mass_content_of_13C_in_vegetation_and_litter_and_soil_and_forestry_and_agricultural_products", "units": "kg m-2", "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacella", "long_name": "Mass of 13C in all terrestrial carbon pools", - "comment": "", + "comment": "'Content' indicates a quantity per unit area. 'Vegetation' means any living plants e.g. trees, shrubs, grass. 'Litter' is dead plant material in or above the soil. The 'soil content' of a quantity refers to the vertical integral from the surface down to the bottom of the soil model. Examples of 'forestry and agricultural products' are paper, cardboard, furniture, timber for construction, biofuels and food for both humans and livestock. Models that simulate land use changes have one or more pools of carbon that represent these products in order to conserve carbon and allow its eventual release into the atmosphere, for example, when the products decompose in landfill sites. 'C' means the element carbon and '13C' is the stable isotope 'carbon-13', having six protons and seven neutrons.", "dimensions": "longitude latitude time", "out_name": "c13Land", "type": "real", @@ -215,12 +215,12 @@ "c13Litter": { "frequency": "mon", "modeling_realm": "land", - "standard_name": "litter_c13_content", + "standard_name": "litter_mass_content_of_13C", "units": "kg m-2", "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacella", "long_name": "Mass of 13C in Litter Pool", - "comment": "", + "comment": "'Content' indicates a quantity per unit area. 'Litter' is dead plant material in or above the soil. 'C' means the element carbon and '13C' is the stable isotope 'carbon-13', having six protons and seven neutrons.", "dimensions": "longitude latitude time", "out_name": "c13Litter", "type": "real", @@ -233,12 +233,12 @@ "c13Soil": { "frequency": "mon", "modeling_realm": "land", - "standard_name": "soil_c13_content", + "standard_name": "soil_mass_content_of_13C", "units": "kg m-2", "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacella", "long_name": "Mass of 13C in Soil Pool", - "comment": "", + "comment": "'Content' indicates a quantity per unit area. The 'soil content' of a quantity refers to the vertical integral from the surface down to the bottom of the soil model. For the content between specified levels in the soil, standard names including 'content_of_soil_layer' are used. 'C' means the element carbon and '13C' is the stable isotope 'carbon-13', having six protons and seven neutrons.", "dimensions": "longitude latitude time", "out_name": "c13Soil", "type": "real", @@ -251,12 +251,12 @@ "c13Veg": { "frequency": "mon", "modeling_realm": "land", - "standard_name": "vegetation_c13_content", + "standard_name": "vegetation_mass_content_of_13C", "units": "kg m-2", "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacella", "long_name": "Mass of 13C in Vegetation", - "comment": "", + "comment": "'Content' indicates a quantity per unit area. 'Vegetation' means any living plants e.g. trees, shrubs, grass. 'C' means the element carbon and '13C' is the stable isotope 'carbon-13', having six protons and seven neutrons.", "dimensions": "longitude latitude time", "out_name": "c13Veg", "type": "real", @@ -269,12 +269,12 @@ "c14Land": { "frequency": "mon", "modeling_realm": "land", - "standard_name": "total_land_c14", + "standard_name": "mass_content_of_14C_in_vegetation_and_litter_and_soil_and_forestry_and_agricultural_products", "units": "kg m-2", "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacella", "long_name": "Mass of 14C in all terrestrial carbon pools", - "comment": "", + "comment": "'Content' indicates a quantity per unit area. 'Vegetation' means any living plants e.g. trees, shrubs, grass. 'Litter' is dead plant material in or above the soil. The 'soil content' of a quantity refers to the vertical integral from the surface down to the bottom of the soil model. Examples of 'forestry and agricultural products' are paper, cardboard, furniture, timber for construction, biofuels and food for both humans and livestock. Models that simulate land use changes have one or more pools of carbon that represent these products in order to conserve carbon and allow its eventual release into the atmosphere, for example, when the products decompose in landfill sites. 'C' means the element carbon and '14C' is the radioactive isotope 'carbon-14', having six protons and eight neutrons and used in radiocarbon dating.", "dimensions": "longitude latitude time", "out_name": "c14Land", "type": "real", @@ -287,12 +287,12 @@ "c14Litter": { "frequency": "mon", "modeling_realm": "land", - "standard_name": "litter_c14_content", + "standard_name": "litter_mass_content_of_14C", "units": "kg m-2", "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacella", "long_name": "Mass of 14C in Litter Pool", - "comment": "", + "comment": "'Content' indicates a quantity per unit area. 'Litter' is dead plant material in or above the soil. 'C' means the element carbon and '14C' is the radioactive isotope 'carbon-14', having six protons and eight neutrons and used in radiocarbon dating.", "dimensions": "longitude latitude time", "out_name": "c14Litter", "type": "real", @@ -305,12 +305,12 @@ "c14Soil": { "frequency": "mon", "modeling_realm": "land", - "standard_name": "soil_c14_content", + "standard_name": "soil_mass_content_of_14C", "units": "kg m-2", "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacella", "long_name": "Mass of 14C in Soil Pool", - "comment": "", + "comment": "'Content' indicates a quantity per unit area. The 'soil content' of a quantity refers to the vertical integral from the surface down to the bottom of the soil model. For the content between specified levels in the soil, standard names including 'content_of_soil_layer' are used. 'C' means the element carbon and '14C' is the radioactive isotope 'carbon-14', having six protons and eight neutrons and used in radiocarbon dating.", "dimensions": "longitude latitude time", "out_name": "c14Soil", "type": "real", @@ -323,12 +323,12 @@ "c14Veg": { "frequency": "mon", "modeling_realm": "land", - "standard_name": "vegetation_c14_content", + "standard_name": "vegetation_mass_content_of_14C", "units": "kg m-2", "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacella", "long_name": "Mass of 14C in Vegetation", - "comment": "", + "comment": "'Content' indicates a quantity per unit area. 'Vegetation' means any living plants e.g. trees, shrubs, grass. 'C' means the element carbon and '14C' is the radioactive isotope 'carbon-14', having six protons and eight neutrons and used in radiocarbon dating.", "dimensions": "longitude latitude time", "out_name": "c14Veg", "type": "real", @@ -382,7 +382,7 @@ "cell_methods": "area: time: mean where natural_grasses (comment: mask=grassFrac)", "cell_measures": "area: areacella", "long_name": "Carbon mass in litter on grass tiles", - "comment": "", + "comment": "'Content' indicates a quantity per unit area. 'Litter carbon' is dead inorganic material in or above the soil quantified as the mass of carbon which it contains.", "dimensions": "longitude latitude time", "out_name": "cLitterGrass", "type": "real", @@ -400,7 +400,7 @@ "cell_methods": "area: time: mean where shrubs (comment: mask=shrubFrac)", "cell_measures": "area: areacella", "long_name": "Carbon mass in litter on shrub tiles", - "comment": "", + "comment": "'Content' indicates a quantity per unit area. 'Litter carbon' is dead inorganic material in or above the soil quantified as the mass of carbon which it contains.", "dimensions": "longitude latitude time", "out_name": "cLitterShrub", "type": "real", @@ -454,7 +454,7 @@ "cell_methods": "area: time: mean where trees (comment: mask=treeFrac)", "cell_measures": "area: areacella", "long_name": "Carbon mass in litter on tree tiles", - "comment": "", + "comment": "'Content' indicates a quantity per unit area. 'Litter carbon' is dead inorganic material in or above the soil quantified as the mass of carbon which it contains.", "dimensions": "longitude latitude time", "out_name": "cLitterTree", "type": "real", @@ -525,9 +525,9 @@ "units": "kg m-2", "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacella", - "long_name": "Carbon mass in soil pool above 1m depth", + "long_name": "Carbon Mass in Soil Pool above 1m Depth", "comment": "Report missing data over ocean grid cells. For fractional land report value averaged over the land fraction.", - "dimensions": "longitude latitude time", + "dimensions": "longitude latitude time sdepth10", "out_name": "cSoilAbove1m", "type": "real", "positive": "", @@ -536,24 +536,6 @@ "ok_min_mean_abs": "", "ok_max_mean_abs": "" }, - "cSoilBelow1m": { - "frequency": "mon", - "modeling_realm": "land", - "standard_name": "soil_carbon_content", - "units": "kg m-2", - "cell_methods": "area: mean where land time: mean", - "cell_measures": "area: areacella", - "long_name": "Carbon Mass in Soil Pool below 1m Depth", - "comment": "", - "dimensions": "longitude latitude time", - "out_name": "cSoilBelow1m", - "type": "real", - "positive": "", - "valid_min": "", - "valid_max": "", - "ok_min_mean_abs": "", - "ok_max_mean_abs": "" - }, "cSoilGrass": { "frequency": "mon", "modeling_realm": "land", @@ -562,7 +544,7 @@ "cell_methods": "area: time: mean where natural_grasses (comment: mask=grassFrac)", "cell_measures": "area: areacella", "long_name": "Carbon mass in soil on grass tiles", - "comment": "", + "comment": "'Content' indicates a quantity per unit area. The 'soil content' of a quantity refers to the vertical integral from the surface down to the bottom of the soil model. For the content between specified levels in the soil, standard names including content_of_soil_layer are used.", "dimensions": "longitude latitude time", "out_name": "cSoilGrass", "type": "real", @@ -591,15 +573,15 @@ "ok_max_mean_abs": "" }, "cSoilPools": { - "frequency": "monPt", + "frequency": "mon", "modeling_realm": "land", - "standard_name": "soil_carbon_content_by_pool", + "standard_name": "soil_carbon_content", "units": "kg m-2", - "cell_methods": "area: mean where land time: point", + "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacella", "long_name": "Carbon mass in each model soil pool (summed over vertical levels)", "comment": "for models with multiple soil carbon pools, report each pool here. If models also have vertical discretaisation these should be aggregated", - "dimensions": "longitude latitude soilpools time1", + "dimensions": "longitude latitude soilpools time", "out_name": "cSoilPools", "type": "real", "positive": "", @@ -616,7 +598,7 @@ "cell_methods": "area: time: mean where shrubs (comment: mask=shrubFrac)", "cell_measures": "area: areacella", "long_name": "Carbon mass in soil on shrub tiles", - "comment": "", + "comment": "'Content' indicates a quantity per unit area. The 'soil content' of a quantity refers to the vertical integral from the surface down to the bottom of the soil model. For the content between specified levels in the soil, standard names including content_of_soil_layer are used.", "dimensions": "longitude latitude time", "out_name": "cSoilShrub", "type": "real", @@ -634,7 +616,7 @@ "cell_methods": "area: time: mean where trees (comment: mask=treeFrac)", "cell_measures": "area: areacella", "long_name": "Carbon mass in soil on tree tiles", - "comment": "", + "comment": "'Content' indicates a quantity per unit area. The 'soil content' of a quantity refers to the vertical integral from the surface down to the bottom of the soil model. For the content between specified levels in the soil, standard names including content_of_soil_layer are used.", "dimensions": "longitude latitude time", "out_name": "cSoilTree", "type": "real", @@ -665,7 +647,7 @@ "cTotFireLut": { "frequency": "mon", "modeling_realm": "land", - "standard_name": "missing", + "standard_name": "surface_upward_mass_flux_of_carbon_dioxide_expressed_as_carbon_due_to_emission_from_fires", "units": "kg m-2 s-1", "cell_methods": "area: time: mean where landuse", "cell_measures": "area: areacella", @@ -688,7 +670,7 @@ "cell_methods": "area: time: mean where natural_grasses (comment: mask=grassFrac)", "cell_measures": "area: areacella", "long_name": "Carbon mass in vegetation on grass tiles", - "comment": "", + "comment": "'Content' indicates a quantity per unit area. 'Vegetation' means any plants e.g. trees, shrubs, grass.", "dimensions": "longitude latitude time", "out_name": "cVegGrass", "type": "real", @@ -706,7 +688,7 @@ "cell_methods": "area: time: mean where shrubs (comment: mask=shrubFrac)", "cell_measures": "area: areacella", "long_name": "Carbon mass in vegetation on shrub tiles", - "comment": "", + "comment": "'Content' indicates a quantity per unit area. 'Vegetation' means any plants e.g. trees, shrubs, grass.", "dimensions": "longitude latitude time", "out_name": "cVegShrub", "type": "real", @@ -724,7 +706,7 @@ "cell_methods": "area: time: mean where trees (comment: mask=treeFrac)", "cell_measures": "area: areacella", "long_name": "Carbon mass in vegetation on tree tiles", - "comment": "", + "comment": "'Content' indicates a quantity per unit area. 'Vegetation' means any plants e.g. trees, shrubs, grass.", "dimensions": "longitude latitude time", "out_name": "cVegTree", "type": "real", @@ -796,7 +778,7 @@ "cell_methods": "time: mean", "cell_measures": "area: areacella", "long_name": "CALIPSO ice cloud Fraction", - "comment": "", + "comment": "'Layer' means any layer with upper and lower boundaries that have constant values in some vertical coordinate. There must be a vertical coordinate variable indicating the extent of the layer(s). If the layers are model layers, the vertical coordinate can be 'model_level_number', but it is recommended to specify a physical coordinate (in a scalar or auxiliary coordinate variable) as well. 'X_area_fraction' means the fraction of horizontal area occupied by X. Cloud area fraction is also called 'cloud amount' and 'cloud cover'.", "dimensions": "longitude latitude alt40 time", "out_name": "clcalipsoice", "type": "real", @@ -922,7 +904,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "MODIS Ice Cloud Area Percentage", - "comment": "", + "comment": "'X_area_fraction' means the fraction of horizontal area occupied by X. Cloud area fraction is also called 'cloud amount' and 'cloud cover'. The cloud area fraction is for the whole atmosphere column, as seen from the surface or the top of the atmosphere. The cloud area fraction in a layer of the atmosphere has the standard name cloud_area_fraction_in_atmosphere_layer.", "dimensions": "longitude latitude time", "out_name": "climodis", "type": "real", @@ -958,7 +940,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "MODIS Total Cloud Cover Percentage", - "comment": "", + "comment": "'X_area_fraction' means the fraction of horizontal area occupied by X. 'X_area' means the horizontal area occupied by X within the grid cell. Cloud area fraction is also called 'cloud amount' and 'cloud cover'. The cloud area fraction is for the whole atmosphere column, as seen from the surface or the top of the atmosphere. The cloud area fraction in a layer of the atmosphere has the standard name cloud_area_fraction_in_atmosphere_layer.", "dimensions": "longitude latitude time", "out_name": "cltmodis", "type": "real", @@ -976,7 +958,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "MODIS Liquid Cloud Fraction", - "comment": "", + "comment": "'X_area_fraction' means the fraction of horizontal area occupied by X. Cloud area fraction is also called 'cloud amount' and 'cloud cover'. The cloud area fraction is for the whole atmosphere column, as seen from the surface or the top of the atmosphere. The cloud area fraction in a layer of the atmosphere has the standard name cloud_area_fraction_in_atmosphere_layer. The chemical formula for water is H2O.", "dimensions": "longitude latitude time", "out_name": "clwmodis", "type": "real", @@ -1205,12 +1187,12 @@ "dissi14c": { "frequency": "mon", "modeling_realm": "ocnBgChem", - "standard_name": "mole_concentration_of_dissolved_inorganic_c14_in_sea_water", + "standard_name": "mole_concentration_of_dissolved_inorganic_carbon14_in_sea_water", "units": "mol m-3", "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello volume: volcello", "long_name": "Concentration of DI14C", - "comment": "", + "comment": "Mole concentration means number of moles per unit volume, also called 'molarity', and is used in the construction 'mole_concentration_of_X_in_Y', where X is a material constituent of Y. A chemical or biological species denoted by X may be described by a single term such as 'nitrogen' or a phrase such as 'nox_expressed_as_nitrogen'. 'Dissolved inorganic carbon' describes a family of chemical species in solution, including carbon dioxide, carbonic acid and the carbonate and bicarbonate anions. 'Dissolved inorganic carbon' is the term used in standard names for all species belonging to the family that are represented within a given model. The list of individual species that are included in a quantity having a group chemical standard name can vary between models. Where possible, the data variable should be accompanied by a complete description of the species represented, for example, by using a comment attribute.", "dimensions": "longitude latitude olevel time", "out_name": "dissi14c", "type": "real", @@ -1229,7 +1211,7 @@ "cell_measures": "area: areacella", "long_name": "Aerosol extinction coefficient", "comment": "Aerosol Extinction at 550nm", - "dimensions": "longitude latitude alevel time", + "dimensions": "longitude latitude alevel time1 lambda550nm", "out_name": "ec550aer", "type": "real", "positive": "", @@ -1300,7 +1282,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello volume: volcello", "long_name": "Sinking Particulate Iron Flux", - "comment": "", + "comment": "In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics. 'Sinking' is the gravitational settling of particulate matter suspended in a liquid. A sinking flux is positive downwards and is calculated relative to the movement of the surrounding fluid.", "dimensions": "longitude latitude olevel time", "out_name": "expfe", "type": "real", @@ -1318,7 +1300,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello volume: volcello", "long_name": "Sinking Particulate Organic Nitrogen Flux", - "comment": "", + "comment": "In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics. 'Sinking' is the gravitational settling of particulate matter suspended in a liquid. A sinking flux is positive downwards and is calculated relative to the movement of the surrounding fluid.", "dimensions": "longitude latitude olevel time", "out_name": "expn", "type": "real", @@ -1336,7 +1318,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello volume: volcello", "long_name": "Sinking Particulate Organic Phosphorus Flux", - "comment": "", + "comment": "In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics. 'Sinking' is the gravitational settling of particulate matter suspended in a liquid. A sinking flux is positive downwards and is calculated relative to the movement of the surrounding fluid.", "dimensions": "longitude latitude olevel time", "out_name": "expp", "type": "real", @@ -1354,7 +1336,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello volume: volcello", "long_name": "Sinking Particulate Silica Flux", - "comment": "", + "comment": "In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics. 'Sinking' is the gravitational settling of particulate matter suspended in a liquid. A sinking flux is positive downwards and is calculated relative to the movement of the surrounding fluid.", "dimensions": "longitude latitude olevel time", "out_name": "expsi", "type": "real", @@ -1371,7 +1353,7 @@ "units": "kg m-2 s-1", "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacella", - "long_name": "carbon mass flux into atmosphere due to any human activity", + "long_name": "Carbon Mass Flux from Vegetation, Litter or Soil Pools into the Atmosphere due to Any Human Activity", "comment": "will require some careful definition to make sure we capture everything - any human activity that releases carbon to the atmosphere instead of into product pool goes here. E.g. Deforestation fire, harvest assumed to decompose straight away, grazing...", "dimensions": "longitude latitude time", "out_name": "fAnthDisturb", @@ -1403,7 +1385,7 @@ "fCLandToOcean": { "frequency": "mon", "modeling_realm": "land", - "standard_name": "carbon_mass_flux_into_ocean_from_rivers", + "standard_name": "mass_flux_of_carbon_into_sea_water_from_rivers", "units": "kg m-2 s-1", "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacellr", @@ -1457,7 +1439,7 @@ "fFireAll": { "frequency": "mon", "modeling_realm": "land", - "standard_name": "fire_CO2_emissions_from_all_sources", + "standard_name": "surface_upward_mass_flux_of_carbon_dioxide_expressed_as_carbon_due_to_emission_from_fires", "units": "kg m-2 s-1", "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacella", @@ -1475,7 +1457,7 @@ "fFireNat": { "frequency": "mon", "modeling_realm": "land", - "standard_name": "fire_CO2_emissions_from_wildfire", + "standard_name": "surface_upward_mass_flux_of_carbon_dioxide_expressed_as_carbon_due_to_emission_from_natural_fires", "units": "kg m-2 s-1", "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacella", @@ -1511,7 +1493,7 @@ "fHarvestToProduct": { "frequency": "mon", "modeling_realm": "land", - "standard_name": "harvested_biomass_into_product_pool", + "standard_name": "mass_flux_of_carbon_into_forestry_and_agricultural_products_due_to_crop_harvesting", "units": "kg m-2 s-1", "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacella", @@ -1529,7 +1511,7 @@ "fLitterFire": { "frequency": "mon", "modeling_realm": "land", - "standard_name": "fire_CO2_emissions_from_litter_carbon", + "standard_name": "surface_upward_mass_flux_of_carbon_dioxide_expressed_as_carbon_due_to_emission_from_litter_in_fires", "units": "kg m-2 s-1", "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacella", @@ -1961,7 +1943,7 @@ "fVegFire": { "frequency": "mon", "modeling_realm": "land", - "standard_name": "fire_CO2_emissions_from_vegetation_carbon", + "standard_name": "surface_upward_mass_flux_of_carbon_dioxide_expressed_as_carbon_due_to_emission_from_vegetation_in_fires", "units": "kg m-2 s-1", "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacella", @@ -1979,7 +1961,7 @@ "fVegLitterMortality": { "frequency": "mon", "modeling_realm": "land", - "standard_name": "mortality_litter_carbon_flux", + "standard_name": "mass_flux_of_carbon_into_litter_from_vegetation_due_to_mortality", "units": "kg m-2 s-1", "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacella", @@ -1997,7 +1979,7 @@ "fVegLitterSenescence": { "frequency": "mon", "modeling_realm": "land", - "standard_name": "senescence_litter_carbon_flux", + "standard_name": "mass_flux_of_carbon_into_litter_from_vegetation_due_to_senescence", "units": "kg m-2 s-1", "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacella", @@ -2015,7 +1997,7 @@ "fVegSoilMortality": { "frequency": "mon", "modeling_realm": "land", - "standard_name": "mortality_vegtosoil_carbon_flux", + "standard_name": "mass_flux_of_carbon_into_soil_from_vegetation_due_to_mortality", "units": "kg m-2 s-1", "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacella", @@ -2033,7 +2015,7 @@ "fVegSoilSenescence": { "frequency": "mon", "modeling_realm": "land", - "standard_name": "senescence_vegtosoil_carbon_flux", + "standard_name": "mass_flux_of_carbon_into_soil_from_vegetation_due_to_senescence", "units": "kg m-2 s-1", "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacella", @@ -2056,7 +2038,7 @@ "cell_methods": "area: time: mean where landuse", "cell_measures": "area: areacella", "long_name": "Anthropogenic heat flux generated from non-renewable human primary energy consumption, including energy use by vehicles, commercial and residential buildings, industry, and power plants. Primary energy refers to energy in natural resources, fossil and nonfossil, before conversion into other forms, such as electricity.", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'Upward' indicates a vector component which is positive when directed upward (negative downward). The vertical heat flux in air is the sum of all heat fluxes i.e. radiative, latent and sensible. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics. The specification of a physical process by the phrase 'due_to_' process means that the quantity named is a single term in a sum of terms which together compose the general quantity named by omitting the phrase. 'Anthropogenic' means influenced, caused, or created by human activity. The heat flux due to anthropogenic energy consumption results from non-renewable human primary energy consumption, including energy use by vehicles, commercial and residential buildings, industry, and power plants. Primary energy refers to energy in natural resources, fossil and non-fossil, before conversion into other forms, such as electricity.", "dimensions": "longitude latitude landUse time", "out_name": "fahLut", "type": "real", @@ -2066,24 +2048,6 @@ "ok_min_mean_abs": "", "ok_max_mean_abs": "" }, - "fbddtalk": { - "frequency": "mon", - "modeling_realm": "ocnBgChem", - "standard_name": "integral_wrt_depth_of_tendency_of_sea_water_alkalinity_expressed_as_mole_equivalent_due_to_biological_processes", - "units": "mol m-2 s-1", - "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", - "long_name": "Rate of Change of Biological Alkalinity due to Biological Activity", - "comment": "vertical integral of net biological terms in time rate of change of alkalinity", - "dimensions": "longitude latitude olevel time", - "out_name": "fbddtalk", - "type": "real", - "positive": "", - "valid_min": "", - "valid_max": "", - "ok_min_mean_abs": "", - "ok_max_mean_abs": "" - }, "fbddtdic": { "frequency": "mon", "modeling_realm": "ocnBgChem", @@ -2102,24 +2066,6 @@ "ok_min_mean_abs": "", "ok_max_mean_abs": "" }, - "fbddtdife": { - "frequency": "mon", - "modeling_realm": "ocnBgChem", - "standard_name": "tendency_of_ocean_mole_content_of_dissolved_inorganic_iron_due_to_biological_processes", - "units": "mol m-2 s-1", - "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", - "long_name": "Rate of Change of Dissolved Inorganic Iron due to Biological Activity", - "comment": "vertical integral of net biological terms in time rate of change of dissolved inorganic iron", - "dimensions": "longitude latitude olevel time", - "out_name": "fbddtdife", - "type": "real", - "positive": "", - "valid_min": "", - "valid_max": "", - "ok_min_mean_abs": "", - "ok_max_mean_abs": "" - }, "fbddtdin": { "frequency": "mon", "modeling_realm": "ocnBgChem", @@ -2200,7 +2146,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello volume: volcello", "long_name": "Rate of Change of Net Dissolved Inorganic Carbon", - "comment": "", + "comment": "'Content' indicates a quantity per unit area. 'tendency_of_X' means derivative of X with respect to time. 'Dissolved inorganic carbon' describes a family of chemical species in solution, including carbon dioxide, carbonic acid and the carbonate and bicarbonate anions. 'Dissolved inorganic carbon' isthe term used in standard names for all species belonging to the family that are represented within a given model. The list of individual species that are included in a quantity having a group chemical standard name can vary between models. Where possible, the data variable should be accompanied by a complete description of the species represented, for example, by using a comment attribute.", "dimensions": "longitude latitude olevel time", "out_name": "fddtdic", "type": "real", @@ -2290,7 +2236,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Total air-sea flux of 14CO2", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'Downward' indicates a vector component which is positive when directed downward (negative upward). In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics. In ocean biogeochemistry models, an 'abiotic analogue' is used to simulate the effect on a modelled variable when biological effects on ocean carbon concentration and alkalinity are ignored. The phrase 'expressed_as' is used in the construction A_expressed_as_B, where B is a chemical constituent of A. It means that the quantity indicated by the standard name is calculated solely with respect to the B contained in A, neglecting all other chemical constituents of A. Carbon14 is a radioactive isotope of carbon having six protons and eight neutrons, used in radiocarbon dating.", "dimensions": "longitude latitude time", "out_name": "fg14co2", "type": "real", @@ -2434,7 +2380,7 @@ "cell_methods": "area: time: mean where landuse", "cell_measures": "area: areacella", "long_name": "gross primary productivity on land use tile", - "comment": "", + "comment": "'Production of carbon' means the production of biomass expressed as the mass of carbon which it contains. Gross primary production is the rate of synthesis of biomass from inorganic precursors by autotrophs ('producers'), for example, photosynthesis in plants or phytoplankton. The producers also respire some of this biomass and the difference is 'net_primary_production'. 'Productivity' means production per unit area. The phrase 'expressed_as' is used in the construction A_expressed_as_B, where B is a chemical constituent of A. It means that the quantity indicated by the standard name is calculated solely with respect to the B contained in A, neglecting all other chemical constituents of A.", "dimensions": "longitude latitude landUse time", "out_name": "gppLut", "type": "real", @@ -2596,7 +2542,7 @@ "cell_methods": "area: time: mean where landuse", "cell_measures": "area: areacella", "long_name": "latent heat flux on land use tile", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'Upward' indicates a vector component which is positive when directed upward (negative downward). The surface latent heat flux is the exchange of heat between the surface and the air on account of evaporation (including sublimation). In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "longitude latitude landUse time", "out_name": "hflsLut", "type": "real", @@ -2614,7 +2560,7 @@ "cell_methods": "area: time: mean where landuse", "cell_measures": "area: areacella", "long_name": "sensible heat flux on land use tile", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'Upward' indicates a vector component which is positive when directed upward (negative downward). The surface sensible heat flux, also called 'turbulent' heat flux, is the exchange of heat between the surface and the air by motion of air. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics. Unless indicated in the cell_methods attribute, a quantity is assumed to apply to the whole area of each horizontal grid box. Previously, the qualifier where_type was used to specify that the quantity applies only to the part of the grid box of the named type. Names containing the where_type qualifier are deprecated and newly created data should use the cell_methods attribute to indicate the horizontal area to which the quantity applies.", "dimensions": "longitude latitude landUse time", "out_name": "hfssLut", "type": "real", @@ -2650,7 +2596,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "Specific Humidity", - "comment": "", + "comment": "'specific' means per unit mass. Specific humidity is the mass fraction of water vapor in (moist) air.", "dimensions": "longitude latitude plev7h time", "out_name": "hus", "type": "real", @@ -2668,7 +2614,7 @@ "cell_methods": "time: mean", "cell_measures": "area: areacella", "long_name": "Specific Humidity", - "comment": "", + "comment": "'specific' means per unit mass. Specific humidity is the mass fraction of water vapor in (moist) air.", "dimensions": "longitude latitude plev27 time", "out_name": "hus", "type": "real", @@ -2794,8 +2740,8 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "MODIS Optical Thickness-Particle Size joint distribution, ice", - "comment": "", - "dimensions": "longitude latitude plev7c effectRadIc tau time", + "comment": "'Layer' means any layer with upper and lower boundaries that have constant values in some vertical coordinate. There must be a vertical coordinate variable indicating the extent of the layer(s). If the layers are model layers, the vertical coordinate can be model_level_number, but it is recommended to specify a physical coordinate (in a scalar or auxiliary coordinate variable) as well. 'X_area_fraction' means the fraction of horizontal area occupied by X. 'X_area' means the horizontal area occupied by X within the grid cell. Cloud area fraction is also called 'cloud amount' and 'cloud cover'.", + "dimensions": "longitude latitude effectRadIc tau time", "out_name": "jpdftaureicemodis", "type": "real", "positive": "", @@ -2812,8 +2758,8 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "MODIS Optical Thickness-Particle Size joint distribution, liquid", - "comment": "", - "dimensions": "longitude latitude plev7c effectRadLi tau time", + "comment": "'Layer' means any layer with upper and lower boundaries that have constant values in some vertical coordinate. There must be a vertical coordinate variable indicating the extent of the layer(s). If the layers are model layers, the vertical coordinate can be model_level_number, but it is recommended to specify a physical coordinate (in a scalar or auxiliary coordinate variable) as well. 'X_area_fraction' means the fraction of horizontal area occupied by X. 'X_area' means the horizontal area occupied by X within the grid cell. Cloud area fraction is also called 'cloud amount' and 'cloud cover'.", + "dimensions": "longitude latitude effectRadLi tau time", "out_name": "jpdftaureliqmodis", "type": "real", "positive": "", @@ -2825,7 +2771,7 @@ "laiLut": { "frequency": "mon", "modeling_realm": "land", - "standard_name": "missing", + "standard_name": "leaf_area_index", "units": "1", "cell_methods": "area: time: mean where landuse", "cell_measures": "area: areacella", @@ -3010,7 +2956,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "NO3 aerosol mass mixing ratio", - "comment": "", + "comment": "Mass fraction is used in the construction mass_fraction_of_X_in_Y, where X is a material constituent of Y. It means the ratio of the mass of X to the mass of Y (including X). 'Mass_fraction_of_nitrate' means that the mass is expressed as mass of NO3. 'Aerosol' means the system of suspended liquid or solid particles in air (except cloud droplets) and their carrier gas, the air itself. Aerosol particles take up ambient water (a process known as hygroscopic growth) depending on the relative humidity and the composition of the particles. 'Dry aerosol particles' means aerosol particles without any water uptake.", "dimensions": "longitude latitude time", "out_name": "mmrno3", "type": "real", @@ -3059,7 +3005,7 @@ "mrsfl": { "frequency": "mon", "modeling_realm": "land", - "standard_name": "frozen_moisture_content_of_soil_layer", + "standard_name": "frozen_water_content_of_soil_layer", "units": "kg m-2", "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacella", @@ -3077,7 +3023,7 @@ "mrsll": { "frequency": "mon", "modeling_realm": "land", - "standard_name": "liquid_moisture_content_of_soil_layer", + "standard_name": "liquid_water_content_of_soil_layer", "units": "kg m-2", "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacella", @@ -3100,7 +3046,7 @@ "cell_methods": "area: time: mean where landuse", "cell_measures": "area: areacella", "long_name": "Total soil moisture", - "comment": "", + "comment": "alias::soil_moisture_content", "dimensions": "longitude latitude landUse time", "out_name": "mrsoLut", "type": "real", @@ -3275,7 +3221,7 @@ "nMineral": { "frequency": "mon", "modeling_realm": "land", - "standard_name": "mineral_soil_nitrogen_content", + "standard_name": "soil_mass_content_of_inorganic_nitrogen_expressed_as_nitrogen", "units": "kg m-2", "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacella", @@ -3293,7 +3239,7 @@ "nMineralNH4": { "frequency": "mon", "modeling_realm": "land", - "standard_name": "mineral_nh4_soil_nitrogen_content", + "standard_name": "soil_mass_content_of_inorganic_ammonium_expressed_as_nitrogen", "units": "kg m-2", "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacella", @@ -3311,7 +3257,7 @@ "nMineralNO3": { "frequency": "mon", "modeling_realm": "land", - "standard_name": "mineral_no3_soil_nitrogen_content", + "standard_name": "soil_mass_content_of_inorganic_nitrate_expressed_as_nitrogen", "units": "kg m-2", "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacella", @@ -3550,7 +3496,7 @@ "cell_methods": "area: time: mean where landuse", "cell_measures": "area: areacella", "long_name": "net primary productivity on land use tile", - "comment": "", + "comment": "'Production of carbon' means the production of biomass expressed as the mass of carbon which it contains. Net primary production is the excess of gross primary production (rate of synthesis of biomass from inorganic precursors) by autotrophs ('producers'), for example, photosynthesis in plants or phytoplankton, over the rate at which the autotrophs themselves respire some of this biomass. 'Productivity' means production per unit area. The phrase 'expressed_as' is used in the construction A_expressed_as_B, where B is a chemical constituent of A. It means that the quantity indicated by the standard name is calculated solely with respect to the B contained in A, neglecting all other chemical constituents of A.", "dimensions": "longitude latitude landUse time", "out_name": "nppLut", "type": "real", @@ -3635,12 +3581,12 @@ "nwdFracLut": { "frequency": "mon", "modeling_realm": "land", - "standard_name": "missing", + "standard_name": "area_fraction", "units": "%", "cell_methods": "area: mean where land over all_area_types time: mean", "cell_measures": "area: areacella", "long_name": "fraction of land use tile tile that is non-woody vegetation ( e.g. herbaceous crops)", - "comment": "", + "comment": "'Area fraction' means the fraction of horizontal area. To specify which area is quantified by a variable of 'area_fraction', provide a coordinate variable or scalar coordinate variable of 'area_type'. Alternatively, if one is defined, use a more specific standard name of 'X_area_fraction' for the fraction of horizontal area occupied by X.", "dimensions": "longitude latitude landUse time typenwd", "out_name": "nwdFracLut", "type": "real", @@ -3748,7 +3694,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello volume: volcello", "long_name": "tendency of sea water conservative temperature expressed as heat content due to residual mean (sum of Eulerian + parameterized) advection", - "comment": "", + "comment": "'tendency_of_X' means derivative of X with respect to time. 'Content' indicates a quantity per unit area. The phrase 'expressed_as_heat_content' means that this quantity is calculated as the specific heat capacity times density of sea water multiplied by the conservative temperature of the sea water in the grid cell. Conservative Temperature is defined as part of the Thermodynamic Equation of Seawater 2010 (TEOS-10) which was adopted in 2010 by the International Oceanographic Commission (IOC). Conservative Temperature is specific potential enthalpy (which has the standard name sea_water_specific_potential_enthalpy) divided by a fixed value of the specific heat capacity of sea water, namely cp_0 = 3991.86795711963 J kg-1 K-1. Conservative Temperature is a more accurate measure of the 'heat content' of sea water, by a factor of one hundred, than is potential temperature. Because of this, it can be regarded as being proportional to the heat content of sea water per unit mass. Reference: www.teos-10.", "dimensions": "longitude latitude olevel time", "out_name": "ocontemprmadvect", "type": "real", @@ -3803,7 +3749,7 @@ "cell_measures": "area: areacella", "long_name": "Stratospheric Optical depth at 550 nm (all aerosols) 2D-field (here we limit the computation of OD to the stratosphere only)", "comment": "From tropopause to stratopause as defined by the model", - "dimensions": "longitude latitude time", + "dimensions": "longitude latitude time lambda550nm", "out_name": "od550aerso", "type": "real", "positive": "", @@ -3815,13 +3761,13 @@ "od550so4so": { "frequency": "mon", "modeling_realm": "atmos", - "standard_name": "missing", + "standard_name": "stratosphere_optical_thickness_due_to_ambient_suplhate_aerosol_particles", "units": "1", "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "Stratospheric Optical depth at 550 nm (sulphate only) 2D-field (here we limit the computation of OD to the stratosphere only)", "comment": "Balkanski - LSCE", - "dimensions": "longitude latitude time", + "dimensions": "longitude latitude time lambda550nm", "out_name": "od550so4so", "type": "real", "positive": "", @@ -3874,7 +3820,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "integral wrt depth of product of sea water density and potential temperature", - "comment": "", + "comment": "The phrase 'integral_wrt_X_of_Y' means int Y dX. The data variable should have an axis for X specifying the limits of the integral as bounds. The phrase 'wrt' means 'with respect to'. The phrase 'product_of_X_and_Y' means X*Y. Depth is the vertical distance below the surface. Sea water density is the in-situ density (not the potential density). For Boussinesq models, density is the constant Boussinesq reference density, a quantity which has the standard name reference_sea_water_density_for_boussinesq_approximation. Potential temperature is the temperature a parcel of air or sea water would have if moved adiabatically to sea level pressure.", "dimensions": "longitude latitude time", "out_name": "opottempmint", "type": "real", @@ -3946,7 +3892,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello volume: volcello", "long_name": "tendency of sea water potential temperature expressed as heat content due to residual mean advection", - "comment": "", + "comment": "The phrase 'tendency_of_X' means derivative of X with respect to time. 'Content' indicates a quantity per unit area. The phrase 'expressed_as_heat_content' means that this quantity is calculated as the specific heat capacity times density of sea water multiplied by the potential temperature of the sea water in the grid cell. Potential temperature is the temperature a parcel of air or sea water would have if moved adiabatically to sea level pressure. The specification of a physical process by the phrase due_to_process means that the quantity named is a single term in a sum of terms which together compose the general quantity named by omitting the phrase. The phrase 'residual_mean_advection' refers to the sum of the model's resolved advective transport plus any parameterized advective transport. Parameterized advective transport includes processes such as parameterized mesoscale and submesoscale transport, as well as any other advectively parameterized transport.", "dimensions": "longitude latitude olevel time", "out_name": "opottemprmadvect", "type": "real", @@ -4072,7 +4018,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello volume: volcello", "long_name": "tendency of sea water salinity expressed as salt content due to residual mean advection", - "comment": "", + "comment": "The phrase 'tendency_of_X' means derivative of X with respect to time. 'Content' indicates a quantity per unit area. The specification of a physical process by the phrase due_to_process means that the quantity named is a single term in a sum of terms which together compose the general quantity named by omitting the phrase. The phrase 'residual_mean_advection' refers to the sum of the model's resolved advective transport plus any parameterized advective transport. Parameterized advective transport includes processes such as parameterized mesoscale and submesoscale transport, as well as any other advectively parameterized transport. When the parameterized advective transport is represented in the model as a skew-diffusion rather than an advection, then the parameterized skew diffusion should be included in this diagnostic, since the convergence of skew-fluxes are identical (in the continuous formulation) to the convergence of advective fluxes.", "dimensions": "longitude latitude olevel time", "out_name": "osaltrmadvect", "type": "real", @@ -4324,7 +4270,7 @@ "cell_methods": "area: mean time: mean within hours time: maximum over hours", "cell_measures": "area: areacella", "long_name": "Maximum Hourly Precipitation Rate", - "comment": "", + "comment": "In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "longitude latitude time", "out_name": "prhmax", "type": "real", @@ -4414,7 +4360,7 @@ "cell_methods": "area: time: mean where landuse", "cell_measures": "area: areacella", "long_name": "plant respiration on land use tile", - "comment": "", + "comment": "'Respiration carbon' refers to the rate at which biomass is respired expressed as the mass of carbon which it contains. Plant respiration is the sum of respiration by parts of plants both above and below the soil. Plants which photosynthesise are autotrophs i.e. 'producers' of the biomass which they respire from inorganic precursors using sunlight for energy. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "longitude latitude landUse time", "out_name": "raLut", "type": "real", @@ -4684,7 +4630,7 @@ "cell_methods": "area: time: mean where landuse", "cell_measures": "area: areacella", "long_name": "soil heterotrophic respiration on land use tile", - "comment": "", + "comment": "'Respiration carbon' refers to the rate at which biomass is respired expressed as the mass of carbon which it contains. Heterotrophic respiration is respiration by heterotrophs ('consumers'), which are organisms (including animals and decomposers) that consume other organisms or dead organic material, rather than synthesising organic material from inorganic precursors using energy from the environment (especially sunlight) as autotrophs ('producers') do. Heterotrophic respiration goes on both above and within the soil. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "longitude latitude landUse time", "out_name": "rhLut", "type": "real", @@ -4796,7 +4742,7 @@ "dimensions": "longitude latitude time", "out_name": "rls", "type": "real", - "positive": "up", + "positive": "down", "valid_min": "", "valid_max": "", "ok_min_mean_abs": "", @@ -4810,7 +4756,7 @@ "cell_methods": "area: time: mean where landuse", "cell_measures": "area: areacella", "long_name": "Surface Upwelling Longwave on Land Use Tile", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'longwave' means longwave radiation. Upwelling radiation is radiation from below. It does not mean 'net upward'. When thought of as being incident on a surface, a radiative flux is sometimes called 'irradiance'. In addition, it is identical with the quantity measured by a cosine-collector light-meter and sometimes called 'vector irradiance'. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "longitude latitude landUse time", "out_name": "rlusLut", "type": "real", @@ -4828,7 +4774,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello volume: volcello", "long_name": "net rate of absorption of shortwave energy in ocean layer", - "comment": "", + "comment": "'shortwave' means shortwave radiation. 'Layer' means any layer with upper and lower boundaries that have constant values in some vertical coordinate. There must be a vertical coordinate variable indicating the extent of the layer(s). If the layers are model layers, the vertical coordinate can be model_level_number, but it is recommended to specify a physical coordinate (in a scalar or auxiliary coordinate variable) as well. Net absorbed radiation is the difference between absorbed and emitted radiation.", "dimensions": "longitude latitude olevel time", "out_name": "rsdoabsorb", "type": "real", @@ -4900,7 +4846,7 @@ "cell_methods": "area: time: mean where landuse", "cell_measures": "area: areacella", "long_name": "Surface Upwelling Shortwave on Land Use Tile", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'shortwave' means shortwave radiation. Upwelling radiation is radiation from below. It does not mean 'net upward'. When thought of as being incident on a surface, a radiative flux is sometimes called 'irradiance'. In addition, it is identical with the quantity measured by a cosine-collector light-meter and sometimes called 'vector irradiance'. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "longitude latitude landUse time", "out_name": "rsusLut", "type": "real", @@ -5039,7 +4985,7 @@ "sweLut": { "frequency": "mon", "modeling_realm": "land", - "standard_name": "missing", + "standard_name": "snow_amount_expressed_as_liquid_water_depth", "units": "m", "cell_methods": "area: time: mean where landuse", "cell_measures": "area: areacella", @@ -5163,15 +5109,15 @@ "ok_max_mean_abs": "" }, "tSoilPools": { - "frequency": "monPt", + "frequency": "mon", "modeling_realm": "land", "standard_name": "soil_carbon_turnover_rate_by_pool", "units": "s-1", - "cell_methods": "area: mean where land time: point", + "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacella", "long_name": "turnover rate of each model soil carbon pool", "comment": "defined as 1/(turnover time) for each soil pool. Use the same pools reported under cSoilPools", - "dimensions": "longitude latitude soilpools time1", + "dimensions": "longitude latitude soilpools time", "out_name": "tSoilPools", "type": "real", "positive": "", @@ -5206,7 +5152,7 @@ "cell_methods": "area: time: mean where landuse", "cell_measures": "area: areacella", "long_name": "near-surface air temperature (2m above displacement height, i.e. t_ref) on land use tile", - "comment": "", + "comment": "Air temperature is the bulk temperature of the air, not the surface (skin) temperature.", "dimensions": "longitude latitude landUse time height2m", "out_name": "tasLut", "type": "real", @@ -5294,7 +5240,7 @@ "standard_name": "sea_water_potential_temperature", "units": "degC", "cell_methods": "area: time: mean", - "cell_measures": "area: areacella", + "cell_measures": "area: areacello", "long_name": "Depth average potential temperature of upper 2000m", "comment": "Upper 2000m, 2D field", "dimensions": "longitude latitude time depth2000m", @@ -5312,7 +5258,7 @@ "standard_name": "sea_water_potential_temperature", "units": "degC", "cell_methods": "area: time: mean", - "cell_measures": "area: areacella", + "cell_measures": "area: areacello", "long_name": "Depth average potential temperature of upper 300m", "comment": "Upper 300m, 2D field", "dimensions": "longitude latitude time depth300m", @@ -5330,7 +5276,7 @@ "standard_name": "sea_water_potential_temperature", "units": "degC", "cell_methods": "area: time: mean", - "cell_measures": "area: areacella", + "cell_measures": "area: areacello", "long_name": "Depth average potential temperature of upper 700m", "comment": "Upper 700m, 2D field", "dimensions": "longitude latitude time depth700m", @@ -5363,7 +5309,7 @@ "tnhusscp": { "frequency": "mon", "modeling_realm": "atmos", - "standard_name": "tendency_of_specific_humidity_due_to_stratiform_clouds_and_precipitation", + "standard_name": "tendency_of_specific_humidity_due_to_stratiform_cloud_and_precipitation", "units": "s-1", "cell_methods": "area: time: mean", "cell_measures": "area: areacella", @@ -5507,7 +5453,7 @@ "tntscp": { "frequency": "mon", "modeling_realm": "atmos", - "standard_name": "tendency_of_air_temperature_due_to_stratiform_clouds_and_precipitation", + "standard_name": "tendency_of_air_temperature_due_to_stratiform_cloud_and_precipitation", "units": "K s-1", "cell_methods": "area: time: mean", "cell_measures": "area: areacella", @@ -5522,24 +5468,6 @@ "ok_min_mean_abs": "", "ok_max_mean_abs": "" }, - "tomint": { - "frequency": "mon", - "modeling_realm": "ocean", - "standard_name": "integral_wrt_depth_of_product_of_sea_water_density_and_prognostic_temperature", - "units": "1e-3 kg m-2", - "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello", - "long_name": "integral wrt depth of product of sea water density and prognostic temperature", - "comment": "Full column sum of density*cell thickness*prognostic temperature. If the model is Boussinesq, then use Boussinesq reference density for the density factor.", - "dimensions": "longitude latitude time", - "out_name": "tomint", - "type": "real", - "positive": "", - "valid_min": "", - "valid_max": "", - "ok_min_mean_abs": "", - "ok_max_mean_abs": "" - }, "treeFracBdlDcd": { "frequency": "mon", "modeling_realm": "land", @@ -5674,7 +5602,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "Eastward Wind", - "comment": "", + "comment": "'Eastward' indicates a vector component which is positive when directed eastward (negative westward). Wind is defined as a two-dimensional (horizontal) air velocity vector, with no vertical component. (Vertical motion in the atmosphere has the standard name upward_air_velocity.)", "dimensions": "longitude latitude plev7h time", "out_name": "ua", "type": "real", @@ -5692,7 +5620,7 @@ "cell_methods": "time: mean", "cell_measures": "area: areacella", "long_name": "Eastward Wind", - "comment": "", + "comment": "'Eastward' indicates a vector component which is positive when directed eastward (negative westward). Wind is defined as a two-dimensional (horizontal) air velocity vector, with no vertical component. (Vertical motion in the atmosphere has the standard name upward_air_velocity.)", "dimensions": "longitude latitude plev27 time", "out_name": "ua", "type": "real", @@ -5836,7 +5764,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "Northward Wind", - "comment": "", + "comment": "'Northward' indicates a vector component which is positive when directed northward (negative southward). Wind is defined as a two-dimensional (horizontal) air velocity vector, with no vertical component. (Vertical motion in the atmosphere has the standard name upward_air_velocity.)", "dimensions": "longitude latitude plev7h time", "out_name": "va", "type": "real", @@ -5854,7 +5782,7 @@ "cell_methods": "time: mean", "cell_measures": "area: areacella", "long_name": "Northward Wind", - "comment": "", + "comment": "'Northward' indicates a vector component which is positive when directed northward (negative southward). Wind is defined as a two-dimensional (horizontal) air velocity vector, with no vertical component. (Vertical motion in the atmosphere has the standard name upward_air_velocity.)", "dimensions": "longitude latitude plev27 time", "out_name": "va", "type": "real", @@ -5890,7 +5818,7 @@ "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacella", "long_name": "canopy height", - "comment": "", + "comment": "Height is the vertical distance above the surface. 'Canopy' means the plant or vegetation canopy.", "dimensions": "longitude latitude time", "out_name": "vegHeight", "type": "real", @@ -5908,7 +5836,7 @@ "cell_methods": "area: time: mean where crops (comment: mask=cropFrac)", "cell_measures": "area: areacella", "long_name": "Vegetation height averaged over the crop fraction of a grid cell.", - "comment": "", + "comment": "Height is the vertical distance above the surface. 'Canopy' means the plant or vegetation canopy.", "dimensions": "longitude latitude time", "out_name": "vegHeightCrop", "type": "real", @@ -5926,7 +5854,7 @@ "cell_methods": "area: time: mean where natural_grasses (comment: mask=grassFrac)", "cell_measures": "area: areacella", "long_name": "Vegetation height averaged over the grass fraction of a grid cell.", - "comment": "", + "comment": "Height is the vertical distance above the surface. 'Canopy' means the plant or vegetation canopy.", "dimensions": "longitude latitude time", "out_name": "vegHeightGrass", "type": "real", @@ -5944,7 +5872,7 @@ "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacella", "long_name": "Vegetation height averaged over the pasture fraction of a grid cell.", - "comment": "", + "comment": "Height is the vertical distance above the surface. 'Canopy' means the plant or vegetation canopy.", "dimensions": "longitude latitude time", "out_name": "vegHeightPasture", "type": "real", @@ -5962,7 +5890,7 @@ "cell_methods": "area: time: mean where shrubs (comment: mask=shrubFrac)", "cell_measures": "area: areacella", "long_name": "Vegetation height averaged over the shrub fraction of a grid cell.", - "comment": "", + "comment": "Height is the vertical distance above the surface. 'Canopy' means the plant or vegetation canopy.", "dimensions": "longitude latitude time", "out_name": "vegHeightShrub", "type": "real", @@ -5980,7 +5908,7 @@ "cell_methods": "area: time: mean where trees (comment: mask=treeFrac)", "cell_measures": "area: areacella", "long_name": "Vegetation height averaged over the tree fraction of a grid cell.", - "comment": "", + "comment": "Height is the vertical distance above the surface. 'Canopy' means the plant or vegetation canopy.", "dimensions": "longitude latitude time", "out_name": "vegHeightTree", "type": "real", @@ -6137,12 +6065,12 @@ "wetlandCH4cons": { "frequency": "mon", "modeling_realm": "land", - "standard_name": "wetland_methane_consumption", + "standard_name": "surface_downward_mass_flux_of_methane_due_to_wetland_biological_consumption", "units": "kg m-2 s-1", "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacella", "long_name": "Grid averaged methane consuption (methanotrophy) from wetlands", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'Downward' indicates a vector component which is positive when directed downward (negative upward). In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics. The chemical formula for methane is CH4. The mass is the total mass of the molecules. The specification of a physical process by the phrase 'due_to_' process means that the quantity named is a single term in a sum of terms which together compose the general quantity named by omitting the phrase. Wetlands are areas where water covers the soil, or is present either at or near the surface of the soil all year or for varying periods of time during the year, including during the growing season. The precise conditions under which wetlands produce and consume methane can vary between models.", "dimensions": "longitude latitude time", "out_name": "wetlandCH4cons", "type": "real", @@ -6155,7 +6083,7 @@ "wetlandCH4prod": { "frequency": "mon", "modeling_realm": "land", - "standard_name": "wetland_methane_production", + "standard_name": "surface_upward_mass_flux_of_methane_due_to_emission_from_wetland_biological_production", "units": "kg m-2 s-1", "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacella", @@ -6191,12 +6119,12 @@ "wtd": { "frequency": "mon", "modeling_realm": "land", - "standard_name": "depth_of_soil_moisture_saturation", + "standard_name": "water_table_depth", "units": "m", "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacellr", "long_name": "Water table depth from surface.", - "comment": "", + "comment": "Depth is the vertical distance below the surface. The water table is the surface below which the soil is saturated with water such that all pore spaces are filled.", "dimensions": "longitude latitude time", "out_name": "wtd", "type": "real", @@ -6250,7 +6178,7 @@ "cell_methods": "time: mean", "cell_measures": "area: areacella", "long_name": "Geopotential Height", - "comment": "", + "comment": "Geopotential is the sum of the specific gravitational potential energy relative to the geoid and the specific centripetal potential energy. Geopotential height is the geopotential divided by the standard acceleration due to gravity. It is numerically similar to the altitude (or geometric height) and not to the quantity with standard name height, which is relative to the surface.", "dimensions": "longitude latitude plev27 time", "out_name": "zg", "type": "real", diff --git a/TestTables/CMIP6_EmonZ.json b/TestTables/CMIP6_EmonZ.json index bb2d8aad..9ce754b0 100644 --- a/TestTables/CMIP6_EmonZ.json +++ b/TestTables/CMIP6_EmonZ.json @@ -1,10 +1,10 @@ { "Header": { - "data_specs_version": "01.00.21", + "data_specs_version": "01.00.23", + "cmor_version": "3.3", "table_id": "Table EmonZ", "realm": "atmos", - "cmor_version": "3.2", - "table_date": "14 February 2018", + "table_date": "21 March 2018", "missing_value": "1e20", "int_missing_value": "-999", "product": "model-output", @@ -89,7 +89,7 @@ "oxloss": { "frequency": "mon", "modeling_realm": "atmosChem", - "standard_name": "tendency_of_mole_concentration_of_ozone_and_atomic_oxygen_and_1D_oxygen_atom_due_to_chemical_destruction", + "standard_name": "tendency_of_atmosphere_mole_concentration_of_ox_due_to_chemical_destruction", "units": "mol m-3 s-1", "cell_methods": "longitude: mean time: mean", "cell_measures": "", @@ -107,7 +107,7 @@ "oxprod": { "frequency": "mon", "modeling_realm": "atmosChem", - "standard_name": "tendency_of_mole_concentration_of_ozone_and_atomic_oxygen_and_1D_oxygen_atom_due_to_chemical_production_and_photolysis", + "standard_name": "tendency_of_atmosphere_mole_concentration_of_ox_due_to_chemical_and_photolytic_production", "units": "mol m-3 s-1", "cell_methods": "longitude: mean time: mean", "cell_measures": "", @@ -305,7 +305,7 @@ "tntscp": { "frequency": "mon", "modeling_realm": "atmos", - "standard_name": "tendency_of_air_temperature_due_to_stratiform_clouds_and_precipitation", + "standard_name": "tendency_of_air_temperature_due_to_stratiform_cloud_and_precipitation", "units": "K s-1", "cell_methods": "longitude: mean time: mean", "cell_measures": "", @@ -359,7 +359,7 @@ "vmrox": { "frequency": "mon", "modeling_realm": "atmosChem", - "standard_name": "mole_fraction_of_ozone_and_atomic_oxygen_and_1D_oxygen_atom", + "standard_name": "mole_fraction_of_ox_in_air", "units": "mol mol-1", "cell_methods": "longitude: mean time: mean", "cell_measures": "", @@ -413,7 +413,7 @@ "wtem": { "frequency": "mon", "modeling_realm": "atmos", - "standard_name": "unset", + "standard_name": "upward_transformed_eulerian_mean_air_velocity", "units": "m s-1", "cell_methods": "longitude: mean time: mean", "cell_measures": "", diff --git a/TestTables/CMIP6_Esubhr.json b/TestTables/CMIP6_Esubhr.json index b2c720e8..b3442f16 100644 --- a/TestTables/CMIP6_Esubhr.json +++ b/TestTables/CMIP6_Esubhr.json @@ -1,10 +1,10 @@ { "Header": { - "data_specs_version": "01.00.21", + "data_specs_version": "01.00.23", + "cmor_version": "3.3", "table_id": "Table Esubhr", "realm": "atmos", - "cmor_version": "3.2", - "table_date": "14 February 2018", + "table_date": "21 March 2018", "missing_value": "1e20", "int_missing_value": "-999", "product": "model-output", @@ -40,7 +40,7 @@ "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", "long_name": "Surface Upward Latent Heat Flux", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'Upward' indicates a vector component which is positive when directed upward (negative downward). The surface latent heat flux is the exchange of heat between the surface and the air on account of evaporation (including sublimation). In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "longitude latitude time1", "out_name": "hfls", "type": "real", @@ -58,7 +58,7 @@ "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", "long_name": "Surface Upward Sensible Heat Flux", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'Upward' indicates a vector component which is positive when directed upward (negative downward). The surface sensible heat flux, also called 'turbulent' heat flux, is the exchange of heat between the surface and the air by motion of air. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics. Unless indicated in the cell_methods attribute, a quantity is assumed to apply to the whole area of each horizontal grid box. Previously, the qualifier where_type was used to specify that the quantity applies only to the part of the grid box of the named type. Names containing the where_type qualifier are deprecated and newly created data should use the cell_methods attribute to indicate the horizontal area to which the quantity applies.", "dimensions": "longitude latitude time1", "out_name": "hfss", "type": "real", @@ -76,7 +76,7 @@ "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", "long_name": "Specific Humidity", - "comment": "", + "comment": "'specific' means per unit mass. Specific humidity is the mass fraction of water vapor in (moist) air.", "dimensions": "longitude latitude alevel time1", "out_name": "hus", "type": "real", @@ -395,7 +395,7 @@ "tnhusscp": { "frequency": "subhrPt", "modeling_realm": "atmos", - "standard_name": "tendency_of_specific_humidity_due_to_stratiform_clouds_and_precipitation", + "standard_name": "tendency_of_specific_humidity_due_to_stratiform_cloud_and_precipitation", "units": "s-1", "cell_methods": "area: point time: point", "cell_measures": "", @@ -539,7 +539,7 @@ "tntscp": { "frequency": "subhrPt", "modeling_realm": "atmos", - "standard_name": "tendency_of_air_temperature_due_to_stratiform_clouds_and_precipitation", + "standard_name": "tendency_of_air_temperature_due_to_stratiform_cloud_and_precipitation", "units": "K s-1", "cell_methods": "area: point time: point", "cell_measures": "", @@ -562,7 +562,7 @@ "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", "long_name": "Eastward Wind", - "comment": "", + "comment": "'Eastward' indicates a vector component which is positive when directed eastward (negative westward). Wind is defined as a two-dimensional (horizontal) air velocity vector, with no vertical component. (Vertical motion in the atmosphere has the standard name upward_air_velocity.)", "dimensions": "longitude latitude alevel time1", "out_name": "ua", "type": "real", @@ -580,7 +580,7 @@ "cell_methods": "area: mean time: point", "cell_measures": "area: areacella", "long_name": "Northward Wind", - "comment": "", + "comment": "'Northward' indicates a vector component which is positive when directed northward (negative southward). Wind is defined as a two-dimensional (horizontal) air velocity vector, with no vertical component. (Vertical motion in the atmosphere has the standard name upward_air_velocity.)", "dimensions": "longitude latitude alevel time1", "out_name": "va", "type": "real", diff --git a/TestTables/CMIP6_Eyr.json b/TestTables/CMIP6_Eyr.json index b6ea9bbb..9d0da476 100644 --- a/TestTables/CMIP6_Eyr.json +++ b/TestTables/CMIP6_Eyr.json @@ -1,10 +1,10 @@ { "Header": { - "data_specs_version": "01.00.21", + "data_specs_version": "01.00.23", + "cmor_version": "3.3", "table_id": "Table Eyr", "realm": "land", - "cmor_version": "3.2", - "table_date": "14 February 2018", + "table_date": "21 March 2018", "missing_value": "1e20", "int_missing_value": "-999", "product": "model-output", @@ -89,7 +89,7 @@ "cProductLut": { "frequency": "yrPt", "modeling_realm": "land", - "standard_name": "carbon_content_in_wood_and_agricultural_products", + "standard_name": "carbon_content_of_products_of_anthropogenic_land_use_change", "units": "kg m-2", "cell_methods": "area: mean where landuse time: point", "cell_measures": "area: areacella", diff --git a/TestTables/CMIP6_IfxAnt.json b/TestTables/CMIP6_IfxAnt.json index afdf5617..a37ab8de 100644 --- a/TestTables/CMIP6_IfxAnt.json +++ b/TestTables/CMIP6_IfxAnt.json @@ -1,10 +1,10 @@ { "Header": { - "data_specs_version": "01.00.21", + "data_specs_version": "01.00.23", + "cmor_version": "3.3", "table_id": "Table IfxAnt", "realm": "landIce", - "cmor_version": "3.2", - "table_date": "14 February 2018", + "table_date": "21 March 2018", "missing_value": "1e20", "int_missing_value": "-999", "product": "model-output", diff --git a/TestTables/CMIP6_IfxGre.json b/TestTables/CMIP6_IfxGre.json index 9f6a4358..e34e2624 100644 --- a/TestTables/CMIP6_IfxGre.json +++ b/TestTables/CMIP6_IfxGre.json @@ -1,10 +1,10 @@ { "Header": { - "data_specs_version": "01.00.21", + "data_specs_version": "01.00.23", + "cmor_version": "3.3", "table_id": "Table IfxGre", "realm": "landIce", - "cmor_version": "3.2", - "table_date": "14 February 2018", + "table_date": "21 March 2018", "missing_value": "1e20", "int_missing_value": "-999", "product": "model-output", diff --git a/TestTables/CMIP6_ImonAnt.json b/TestTables/CMIP6_ImonAnt.json index 9f726f19..a416a607 100644 --- a/TestTables/CMIP6_ImonAnt.json +++ b/TestTables/CMIP6_ImonAnt.json @@ -1,10 +1,10 @@ { "Header": { - "data_specs_version": "01.00.21", + "data_specs_version": "01.00.23", + "cmor_version": "3.3", "table_id": "Table ImonAnt", "realm": "atmos", - "cmor_version": "3.2", - "table_date": "14 February 2018", + "table_date": "21 March 2018", "missing_value": "1e20", "int_missing_value": "-999", "product": "model-output", @@ -40,7 +40,7 @@ "cell_methods": "area: time: mean where ice_sheet", "cell_measures": "area: areacellg", "long_name": "Surface Upward Latent Heat Flux", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'Upward' indicates a vector component which is positive when directed upward (negative downward). The surface latent heat flux is the exchange of heat between the surface and the air on account of evaporation (including sublimation). In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "xant yant time", "out_name": "hfls", "type": "real", @@ -58,7 +58,7 @@ "cell_methods": "area: time: mean where ice_sheet", "cell_measures": "area: areacellg", "long_name": "Surface Upward Sensible Heat Flux", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'Upward' indicates a vector component which is positive when directed upward (negative downward). The surface sensible heat flux, also called 'turbulent' heat flux, is the exchange of heat between the surface and the air by motion of air. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics. Unless indicated in the cell_methods attribute, a quantity is assumed to apply to the whole area of each horizontal grid box. Previously, the qualifier where_type was used to specify that the quantity applies only to the part of the grid box of the named type. Names containing the where_type qualifier are deprecated and newly created data should use the cell_methods attribute to indicate the horizontal area to which the quantity applies.", "dimensions": "xant yant time", "out_name": "hfss", "type": "real", @@ -256,7 +256,7 @@ "cell_methods": "area: time: mean where ice_sheet", "cell_measures": "area: areacellg", "long_name": "Rainfall Flux over Land Ice", - "comment": "", + "comment": "In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "xant yant time", "out_name": "prra", "type": "real", @@ -292,7 +292,7 @@ "cell_methods": "area: time: mean where ice_sheet", "cell_measures": "area: areacellg", "long_name": "Surface Downwelling Longwave Radiation", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'longwave' means longwave radiation. Downwelling radiation is radiation from above. It does not mean 'net downward'. When thought of as being incident on a surface, a radiative flux is sometimes called 'irradiance'. In addition, it is identical with the quantity measured by a cosine-collector light-meter and sometimes called 'vector irradiance'. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "xant yant time", "out_name": "rlds", "type": "real", @@ -310,7 +310,7 @@ "cell_methods": "area: time: mean where ice_sheet", "cell_measures": "area: areacellg", "long_name": "Surface Upwelling Longwave Radiation", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'longwave' means longwave radiation. Upwelling radiation is radiation from below. It does not mean 'net upward'. When thought of as being incident on a surface, a radiative flux is sometimes called 'irradiance'. In addition, it is identical with the quantity measured by a cosine-collector light-meter and sometimes called 'vector irradiance'. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "xant yant time", "out_name": "rlus", "type": "real", @@ -346,7 +346,7 @@ "cell_methods": "area: time: mean where ice_sheet", "cell_measures": "area: areacellg", "long_name": "Surface Upwelling Shortwave Radiation", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'shortwave' means shortwave radiation. Upwelling radiation is radiation from below. It does not mean 'net upward'. When thought of as being incident on a surface, a radiative flux is sometimes called 'irradiance'. In addition, it is identical with the quantity measured by a cosine-collector light-meter and sometimes called 'vector irradiance'. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "xant yant time", "out_name": "rsus", "type": "real", diff --git a/TestTables/CMIP6_ImonGre.json b/TestTables/CMIP6_ImonGre.json index f1066fbb..cb75a75c 100644 --- a/TestTables/CMIP6_ImonGre.json +++ b/TestTables/CMIP6_ImonGre.json @@ -1,10 +1,10 @@ { "Header": { - "data_specs_version": "01.00.21", + "data_specs_version": "01.00.23", + "cmor_version": "3.3", "table_id": "Table ImonGre", "realm": "atmos", - "cmor_version": "3.2", - "table_date": "14 February 2018", + "table_date": "21 March 2018", "missing_value": "1e20", "int_missing_value": "-999", "product": "model-output", @@ -40,7 +40,7 @@ "cell_methods": "area: time: mean where ice_sheet", "cell_measures": "area: areacellg", "long_name": "Surface Upward Latent Heat Flux", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'Upward' indicates a vector component which is positive when directed upward (negative downward). The surface latent heat flux is the exchange of heat between the surface and the air on account of evaporation (including sublimation). In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "xgre ygre time", "out_name": "hfls", "type": "real", @@ -58,7 +58,7 @@ "cell_methods": "area: time: mean where ice_sheet", "cell_measures": "area: areacellg", "long_name": "Surface Upward Sensible Heat Flux", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'Upward' indicates a vector component which is positive when directed upward (negative downward). The surface sensible heat flux, also called 'turbulent' heat flux, is the exchange of heat between the surface and the air by motion of air. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics. Unless indicated in the cell_methods attribute, a quantity is assumed to apply to the whole area of each horizontal grid box. Previously, the qualifier where_type was used to specify that the quantity applies only to the part of the grid box of the named type. Names containing the where_type qualifier are deprecated and newly created data should use the cell_methods attribute to indicate the horizontal area to which the quantity applies.", "dimensions": "xgre ygre time", "out_name": "hfss", "type": "real", @@ -256,7 +256,7 @@ "cell_methods": "area: time: mean where ice_sheet", "cell_measures": "area: areacellg", "long_name": "Rainfall Flux over Land Ice", - "comment": "", + "comment": "In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "xgre ygre time", "out_name": "prra", "type": "real", @@ -292,7 +292,7 @@ "cell_methods": "area: time: mean where ice_sheet", "cell_measures": "area: areacellg", "long_name": "Surface Downwelling Longwave Radiation", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'longwave' means longwave radiation. Downwelling radiation is radiation from above. It does not mean 'net downward'. When thought of as being incident on a surface, a radiative flux is sometimes called 'irradiance'. In addition, it is identical with the quantity measured by a cosine-collector light-meter and sometimes called 'vector irradiance'. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "xgre ygre time", "out_name": "rlds", "type": "real", @@ -310,7 +310,7 @@ "cell_methods": "area: time: mean where ice_sheet", "cell_measures": "area: areacellg", "long_name": "Surface Upwelling Longwave Radiation", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'longwave' means longwave radiation. Upwelling radiation is radiation from below. It does not mean 'net upward'. When thought of as being incident on a surface, a radiative flux is sometimes called 'irradiance'. In addition, it is identical with the quantity measured by a cosine-collector light-meter and sometimes called 'vector irradiance'. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "xgre ygre time", "out_name": "rlus", "type": "real", @@ -346,7 +346,7 @@ "cell_methods": "area: time: mean where ice_sheet", "cell_measures": "area: areacellg", "long_name": "Surface Upwelling Shortwave Radiation", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'shortwave' means shortwave radiation. Upwelling radiation is radiation from below. It does not mean 'net upward'. When thought of as being incident on a surface, a radiative flux is sometimes called 'irradiance'. In addition, it is identical with the quantity measured by a cosine-collector light-meter and sometimes called 'vector irradiance'. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "xgre ygre time", "out_name": "rsus", "type": "real", diff --git a/TestTables/CMIP6_IyrAnt.json b/TestTables/CMIP6_IyrAnt.json index 0718cb22..58a97a63 100644 --- a/TestTables/CMIP6_IyrAnt.json +++ b/TestTables/CMIP6_IyrAnt.json @@ -1,10 +1,10 @@ { "Header": { - "data_specs_version": "01.00.21", + "data_specs_version": "01.00.23", + "cmor_version": "3.3", "table_id": "Table IyrAnt", "realm": "atmos", - "cmor_version": "3.2", - "table_date": "14 February 2018", + "table_date": "21 March 2018", "missing_value": "1e20", "int_missing_value": "-999", "product": "model-output", @@ -377,7 +377,7 @@ "strbasemag": { "frequency": "yr", "modeling_realm": "landIce", - "standard_name": "magnitude_of_basal_drag_at_land_ice_base", + "standard_name": "magnitude_of_land_ice_basal_drag", "units": "Pa", "cell_methods": "area: time: mean where ice_sheet", "cell_measures": "area: areacellg", diff --git a/TestTables/CMIP6_IyrGre.json b/TestTables/CMIP6_IyrGre.json index 24b49084..ca507fc7 100644 --- a/TestTables/CMIP6_IyrGre.json +++ b/TestTables/CMIP6_IyrGre.json @@ -1,10 +1,10 @@ { "Header": { - "data_specs_version": "01.00.21", + "data_specs_version": "01.00.23", + "cmor_version": "3.3", "table_id": "Table IyrGre", "realm": "atmos", - "cmor_version": "3.2", - "table_date": "14 February 2018", + "table_date": "21 March 2018", "missing_value": "1e20", "int_missing_value": "-999", "product": "model-output", @@ -377,7 +377,7 @@ "strbasemag": { "frequency": "yr", "modeling_realm": "landIce", - "standard_name": "magnitude_of_basal_drag_at_land_ice_base", + "standard_name": "magnitude_of_land_ice_basal_drag", "units": "Pa", "cell_methods": "area: time: mean where ice_sheet", "cell_measures": "area: areacellg", diff --git a/TestTables/CMIP6_LImon.json b/TestTables/CMIP6_LImon.json index ebfac434..ae8c325f 100644 --- a/TestTables/CMIP6_LImon.json +++ b/TestTables/CMIP6_LImon.json @@ -1,10 +1,10 @@ { "Header": { - "data_specs_version": "01.00.21", + "data_specs_version": "01.00.23", + "cmor_version": "3.3", "table_id": "Table LImon", "realm": "landIce land", - "cmor_version": "3.2", - "table_date": "14 February 2018", + "table_date": "21 March 2018", "missing_value": "1e20", "int_missing_value": "-999", "product": "model-output", @@ -256,7 +256,7 @@ "cell_methods": "area: time: mean where ice_sheet", "cell_measures": "area: areacella", "long_name": "Ice Sheet Surface Downwelling Longwave Radiation", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'longwave' means longwave radiation. Downwelling radiation is radiation from above. It does not mean 'net downward'. When thought of as being incident on a surface, a radiative flux is sometimes called 'irradiance'. In addition, it is identical with the quantity measured by a cosine-collector light-meter and sometimes called 'vector irradiance'. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "longitude latitude time", "out_name": "rldsIs", "type": "real", @@ -274,7 +274,7 @@ "cell_methods": "area: time: mean where ice_sheet", "cell_measures": "area: areacella", "long_name": "Ice Sheet Surface Upwelling Longwave Radiation", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'longwave' means longwave radiation. Upwelling radiation is radiation from below. It does not mean 'net upward'. When thought of as being incident on a surface, a radiative flux is sometimes called 'irradiance'. In addition, it is identical with the quantity measured by a cosine-collector light-meter and sometimes called 'vector irradiance'. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "longitude latitude time", "out_name": "rlusIs", "type": "real", @@ -310,7 +310,7 @@ "cell_methods": "area: time: mean where ice_sheet", "cell_measures": "area: areacella", "long_name": "Ice Sheet Surface Upwelling Shortwave Radiation", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'shortwave' means shortwave radiation. Upwelling radiation is radiation from below. It does not mean 'net upward'. When thought of as being incident on a surface, a radiative flux is sometimes called 'irradiance'. In addition, it is identical with the quantity measured by a cosine-collector light-meter and sometimes called 'vector irradiance'. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "longitude latitude time", "out_name": "rsusIs", "type": "real", diff --git a/TestTables/CMIP6_Lmon.json b/TestTables/CMIP6_Lmon.json index 6c6692de..cb547c76 100644 --- a/TestTables/CMIP6_Lmon.json +++ b/TestTables/CMIP6_Lmon.json @@ -1,10 +1,10 @@ { "Header": { - "data_specs_version": "01.00.21", + "data_specs_version": "01.00.23", + "cmor_version": "3.3", "table_id": "Table Lmon", "realm": "land", - "cmor_version": "3.2", - "table_date": "14 February 2018", + "table_date": "21 March 2018", "missing_value": "1e20", "int_missing_value": "-999", "product": "model-output", @@ -490,7 +490,7 @@ "cell_methods": "area: mean where land time: mean", "cell_measures": "area: areacella", "long_name": "Leaf Area Index", - "comment": "", + "comment": "'X_area' means the horizontal area occupied by X within the grid cell.", "dimensions": "longitude latitude time", "out_name": "lai", "type": "real", diff --git a/TestTables/CMIP6_Oclim.json b/TestTables/CMIP6_Oclim.json index 64bc74fc..b18dad68 100644 --- a/TestTables/CMIP6_Oclim.json +++ b/TestTables/CMIP6_Oclim.json @@ -1,10 +1,10 @@ { "Header": { - "data_specs_version": "01.00.21", + "data_specs_version": "01.00.23", + "cmor_version": "3.3", "table_id": "Table Oclim", "realm": "ocean", - "cmor_version": "3.2", - "table_date": "14 February 2018", + "table_date": "21 March 2018", "missing_value": "1e20", "int_missing_value": "-999", "product": "model-output", diff --git a/TestTables/CMIP6_Oday.json b/TestTables/CMIP6_Oday.json index c8f992a2..47b6a570 100644 --- a/TestTables/CMIP6_Oday.json +++ b/TestTables/CMIP6_Oday.json @@ -1,10 +1,10 @@ { "Header": { - "data_specs_version": "01.00.21", + "data_specs_version": "01.00.23", + "cmor_version": "3.3", "table_id": "Table Oday", "realm": "ocnBgChem", - "cmor_version": "3.2", - "table_date": "14 February 2018", + "table_date": "21 March 2018", "missing_value": "1e20", "int_missing_value": "-999", "product": "model-output", @@ -76,7 +76,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Sea Surface Salinity", - "comment": "", + "comment": "Sea surface salinity is the salt content of sea water close to the sea surface, often on the Practical Salinity Scale of 1978. However, the unqualified term 'salinity' is generic and does not necessarily imply any particular method of calculation. The units of salinity are dimensionless and the units attribute should normally be given as 1e-3 or 0.001 i.e. parts per thousand. Sea surface salinity is often abbreviated as 'SSS'. For the salinity of sea water at a particular depth or layer, a data variable of 'sea_water_salinity' or one of the more precisely defined salinities should be used with a vertical coordinate axis.", "dimensions": "longitude latitude time", "out_name": "sos", "type": "real", diff --git a/TestTables/CMIP6_Odec.json b/TestTables/CMIP6_Odec.json index 02858f58..cbf8195d 100644 --- a/TestTables/CMIP6_Odec.json +++ b/TestTables/CMIP6_Odec.json @@ -1,10 +1,10 @@ { "Header": { - "data_specs_version": "01.00.21", + "data_specs_version": "01.00.23", + "cmor_version": "3.3", "table_id": "Table Odec", "realm": "ocean", - "cmor_version": "3.2", - "table_date": "14 February 2018", + "table_date": "21 March 2018", "missing_value": "1e20", "int_missing_value": "-999", "product": "model-output", @@ -32,6 +32,24 @@ "ok_min_mean_abs": "", "ok_max_mean_abs": "" }, + "bigthetao": { + "frequency": "dec", + "modeling_realm": "ocean", + "standard_name": "sea_water_conservative_temperature", + "units": "degC", + "cell_methods": "area: mean where sea time: mean", + "cell_measures": "area: areacello volume: volcello", + "long_name": "Sea Water Convervative Temperature", + "comment": "Sea water conservative temperature (this should be contributed only for models using conservative temperature as prognostic field)", + "dimensions": "longitude latitude olevel time", + "out_name": "bigthetao", + "type": "real", + "positive": "", + "valid_min": "", + "valid_max": "", + "ok_min_mean_abs": "", + "ok_max_mean_abs": "" + }, "bigthetaoga": { "frequency": "dec", "modeling_realm": "ocean", @@ -86,6 +104,24 @@ "ok_min_mean_abs": "", "ok_max_mean_abs": "" }, + "masscello": { + "frequency": "dec", + "modeling_realm": "ocean", + "standard_name": "sea_water_mass_per_unit_area", + "units": "kg m-2", + "cell_methods": "area: mean where sea time: mean", + "cell_measures": "area: areacello volume: volcello", + "long_name": "Sea Water Mass Per Unit Area", + "comment": "Tracer grid-cell mass per unit area used for computing tracer budgets. For Boussinesq models with static ocean grid cell thickness, masscello = rhozero*thickcello, where thickcello is static cell thickness and rhozero is constant Boussinesq reference density. More generally, masscello is time dependent and reported as part of Omon.", + "dimensions": "longitude latitude olevel time", + "out_name": "masscello", + "type": "real", + "positive": "", + "valid_min": "", + "valid_max": "", + "ok_min_mean_abs": "", + "ok_max_mean_abs": "" + }, "masso": { "frequency": "dec", "modeling_realm": "ocean", @@ -104,6 +140,24 @@ "ok_min_mean_abs": "", "ok_max_mean_abs": "" }, + "msftmrho": { + "frequency": "dec", + "modeling_realm": "ocean", + "standard_name": "ocean_meridional_overturning_mass_streamfunction", + "units": "kg s-1", + "cell_methods": "longitude: mean (comment: basin mean[ along zig-zag grid path]) time: mean", + "cell_measures": "", + "long_name": "Ocean Meridional Overturning Mass Streamfunction", + "comment": "Overturning mass streamfunction arising from all advective mass transport processes, resolved and parameterized.", + "dimensions": "latitude rho basin time", + "out_name": "msftmrho", + "type": "real", + "positive": "", + "valid_min": "", + "valid_max": "", + "ok_min_mean_abs": "", + "ok_max_mean_abs": "" + }, "msftmz": { "frequency": "dec", "modeling_realm": "ocean", @@ -122,6 +176,42 @@ "ok_min_mean_abs": "", "ok_max_mean_abs": "" }, + "msftyrho": { + "frequency": "dec", + "modeling_realm": "ocean", + "standard_name": "ocean_y_overturning_mass_streamfunction", + "units": "kg s-1", + "cell_methods": "time: mean grid_longitude: mean", + "cell_measures": "", + "long_name": "Ocean Y Overturning Mass Streamfunction", + "comment": "Overturning mass streamfunction arising from all advective mass transport processes, resolved and parameterized.", + "dimensions": "latitude rho basin time", + "out_name": "msftyrho", + "type": "real", + "positive": "", + "valid_min": "", + "valid_max": "", + "ok_min_mean_abs": "", + "ok_max_mean_abs": "" + }, + "msftyz": { + "frequency": "dec", + "modeling_realm": "ocean", + "standard_name": "ocean_y_overturning_mass_streamfunction", + "units": "kg s-1", + "cell_methods": "time: mean grid_longitude: mean", + "cell_measures": "", + "long_name": "Ocean Y Overturning Mass Streamfunction", + "comment": "Overturning mass streamfunction arising from all advective mass transport processes, resolved and parameterized.", + "dimensions": "latitude olevel basin time", + "out_name": "msftyz", + "type": "real", + "positive": "", + "valid_min": "", + "valid_max": "", + "ok_min_mean_abs": "", + "ok_max_mean_abs": "" + }, "sfdsi": { "frequency": "dec", "modeling_realm": "ocean seaIce", @@ -166,7 +256,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello volume: volcello", "long_name": "Sea Water Salinity", - "comment": "", + "comment": "Sea water salinity is the salt content of sea water, often on the Practical Salinity Scale of 1978. However, the unqualified term 'salinity' is generic and does not necessarily imply any particular method of calculation. The units of salinity are dimensionless and the units attribute should normally be given as 1e-3 or 0.001 i.e. parts per thousand. There are standard names for the more precisely defined salinity quantities: sea_water_knudsen_salinity, S_K (used for salinity observations between 1901 and 1966), sea_water_cox_salinity, S_C (used for salinity observations between 1967 and 1977), sea_water_practical_salinity, S_P (used for salinity observations from 1978 to the present day), sea_water_absolute_salinity, S_A, sea_water_preformed_salinity, S_*, and sea_water_reference_salinity. Practical Salinity is reported on the Practical Salinity Scale of 1978 (PSS-78), and is usually based on the electrical conductivity of sea water in observations since the 1960s.", "dimensions": "longitude latitude olevel time", "out_name": "so", "type": "real", @@ -184,7 +274,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "", "long_name": "Global Mean Sea Water Salinity", - "comment": "", + "comment": "Sea water salinity is the salt content of sea water, often on the Practical Salinity Scale of 1978. However, the unqualified term 'salinity' is generic and does not necessarily imply any particular method of calculation. The units of salinity are dimensionless and the units attribute should normally be given as 1e-3 or 0.001 i.e. parts per thousand. There are standard names for the more precisely defined salinity quantities: sea_water_knudsen_salinity, S_K (used for salinity observations between 1901 and 1966), sea_water_cox_salinity, S_C (used for salinity observations between 1967 and 1977), sea_water_practical_salinity, S_P (used for salinity observations from 1978 to the present day), sea_water_absolute_salinity, S_A, sea_water_preformed_salinity, S_*, and sea_water_reference_salinity. Practical Salinity is reported on the Practical Salinity Scale of 1978 (PSS-78), and is usually based on the electrical conductivity of sea water in observations since the 1960s.", "dimensions": "time", "out_name": "soga", "type": "real", @@ -202,7 +292,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Sea Surface Salinity", - "comment": "", + "comment": "Sea surface salinity is the salt content of sea water close to the sea surface, often on the Practical Salinity Scale of 1978. However, the unqualified term 'salinity' is generic and does not necessarily imply any particular method of calculation. The units of salinity are dimensionless and the units attribute should normally be given as 1e-3 or 0.001 i.e. parts per thousand. Sea surface salinity is often abbreviated as 'SSS'. For the salinity of sea water at a particular depth or layer, a data variable of 'sea_water_salinity' or one of the more precisely defined salinities should be used with a vertical coordinate axis.", "dimensions": "longitude latitude time", "out_name": "sos", "type": "real", @@ -220,7 +310,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "", "long_name": "Global Average Sea Surface Salinity", - "comment": "", + "comment": "Sea surface salinity is the salt content of sea water close to the sea surface, often on the Practical Salinity Scale of 1978. However, the unqualified term 'salinity' is generic and does not necessarily imply any particular method of calculation. The units of salinity are dimensionless and the units attribute should normally be given as 1e-3 or 0.001 i.e. parts per thousand. Sea surface salinity is often abbreviated as 'SSS'. For the salinity of sea water at a particular depth or layer, a data variable of 'sea_water_salinity' or one of the more precisely defined salinities should be used with a vertical coordinate axis.", "dimensions": "time", "out_name": "sosga", "type": "real", @@ -310,7 +400,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello volume: volcello", "long_name": "Ocean Model Cell Thickness", - "comment": "", + "comment": "'Thickness' means the vertical extent of a layer. 'Cell' refers to a model grid-cell.", "dimensions": "longitude latitude olevel time", "out_name": "thkcello", "type": "real", @@ -392,6 +482,24 @@ "ok_min_mean_abs": "", "ok_max_mean_abs": "" }, + "volcello": { + "frequency": "dec", + "modeling_realm": "ocean", + "standard_name": "ocean_volume", + "units": "m3", + "cell_methods": "area: mean where sea time: mean", + "cell_measures": "area: areacello volume: volcello", + "long_name": "Ocean Grid-Cell Volume", + "comment": "grid-cell volume ca. 2000.", + "dimensions": "longitude latitude olevel time", + "out_name": "volcello", + "type": "real", + "positive": "", + "valid_min": "", + "valid_max": "", + "ok_min_mean_abs": "", + "ok_max_mean_abs": "" + }, "volo": { "frequency": "dec", "modeling_realm": "ocean", @@ -436,7 +544,7 @@ "cell_methods": "time: mean", "cell_measures": "--OPT", "long_name": "Sea Water Z Velocity", - "comment": "", + "comment": "A velocity is a vector quantity. 'Upward' indicates a vector component which is positive when directed upward (negative downward).", "dimensions": "longitude latitude olevel time", "out_name": "wo", "type": "real", diff --git a/TestTables/CMIP6_Ofx.json b/TestTables/CMIP6_Ofx.json index 0777eaf4..bbe0ba84 100644 --- a/TestTables/CMIP6_Ofx.json +++ b/TestTables/CMIP6_Ofx.json @@ -1,10 +1,10 @@ { "Header": { - "data_specs_version": "01.00.21", + "data_specs_version": "01.00.23", + "cmor_version": "3.3", "table_id": "Table Ofx", "realm": "ocean", - "cmor_version": "3.2", - "table_date": "14 February 2018", + "table_date": "21 March 2018", "missing_value": "1e20", "int_missing_value": "-999", "product": "model-output", @@ -40,7 +40,7 @@ "cell_methods": "area: mean", "cell_measures": "area: areacello", "long_name": "Region Selection Index", - "comment": "", + "comment": "A variable with the standard name of region contains strings which indicate geographical regions. These strings must be chosen from the standard region list.", "dimensions": "longitude latitude", "out_name": "basin", "type": "integer", @@ -78,7 +78,7 @@ "cell_methods": "area: mean", "cell_measures": "area: areacello", "long_name": "Upward Geothermal Heat Flux at Sea Floor", - "comment": "", + "comment": "'Upward' indicates a vector component which is positive when directed upward (negative downward). In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "longitude latitude", "out_name": "hfgeou", "type": "real", @@ -132,7 +132,7 @@ "cell_methods": "area: mean", "cell_measures": "area: areacello volume: volcello", "long_name": "Ocean Model Cell Thickness", - "comment": "", + "comment": "'Thickness' means the vertical extent of a layer. 'Cell' refers to a model grid-cell.", "dimensions": "longitude latitude olevel", "out_name": "thkcello", "type": "real", diff --git a/TestTables/CMIP6_Omon.json b/TestTables/CMIP6_Omon.json index 664d5e43..5e9df0be 100644 --- a/TestTables/CMIP6_Omon.json +++ b/TestTables/CMIP6_Omon.json @@ -1,10 +1,10 @@ { "Header": { - "data_specs_version": "01.00.21", + "data_specs_version": "01.00.23", + "cmor_version": "3.3", "table_id": "Table Omon", "realm": "ocnBgChem", - "cmor_version": "3.2", - "table_date": "14 February 2018", + "table_date": "21 March 2018", "missing_value": "1e20", "int_missing_value": "-999", "product": "model-output", @@ -38,10 +38,10 @@ "standard_name": "mole_concentration_of_aragonite_expressed_as_carbon_in_sea_water", "units": "mol m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Aragonite Concentration", "comment": "Sum of particulate aragonite components (e.g. Phytoplankton, Detrital, etc.)", - "dimensions": "longitude latitude olevel time", + "dimensions": "longitude latitude time depth0m", "out_name": "arag", "type": "real", "positive": "", @@ -56,10 +56,10 @@ "standard_name": "mole_concentration_of_bacteria_expressed_as_carbon_in_sea_water", "units": "mol m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Bacterial Carbon Concentration", "comment": "Sum of bacterial carbon component concentrations", - "dimensions": "longitude latitude olevel time", + "dimensions": "longitude latitude time depth0m", "out_name": "bacc", "type": "real", "positive": "", @@ -74,10 +74,10 @@ "standard_name": "mole_concentration_of_particulate_organic_matter_expressed_as_iron_in_sea_water", "units": "mol m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Mole Concentration of Particulate Organic Matter expressed as Iron in sea water", "comment": "Sum of particulate organic iron component concentrations", - "dimensions": "longitude latitude olevel time", + "dimensions": "longitude latitude time depth0m", "out_name": "bfe", "type": "real", "positive": "", @@ -95,7 +95,7 @@ "cell_measures": "area: areacello", "long_name": "Surface Mole Concentration of Particulate Organic Matter expressed as Iron in sea water", "comment": "sum of particulate organic iron component concentrations", - "dimensions": "longitude latitude time depth0m", + "dimensions": "longitude latitude time", "out_name": "bfeos", "type": "real", "positive": "", @@ -146,10 +146,10 @@ "standard_name": "mole_concentration_of_particulate_matter_expressed_as_silicon_in_sea_water", "units": "mol m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Mole Concentration of Particulate Organic Matter expressed as silicon in sea water", "comment": "Sum of particulate silica component concentrations", - "dimensions": "longitude latitude olevel time", + "dimensions": "longitude latitude time depth0m", "out_name": "bsi", "type": "real", "positive": "", @@ -167,7 +167,7 @@ "cell_measures": "area: areacello", "long_name": "Surface Mole Concentration of Particulate Organic Matter expressed as Silicon in sea water", "comment": "sum of particulate silica component concentrations", - "dimensions": "longitude latitude time depth0m", + "dimensions": "longitude latitude time", "out_name": "bsios", "type": "real", "positive": "", @@ -182,10 +182,10 @@ "standard_name": "mole_concentration_of_calcite_expressed_as_carbon_in_sea_water", "units": "mol m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Calcite Concentration", "comment": "Sum of particulate calcite component concentrations (e.g. Phytoplankton, Detrital, etc.)", - "dimensions": "longitude latitude olevel time", + "dimensions": "longitude latitude time depth0m", "out_name": "calc", "type": "real", "positive": "", @@ -202,7 +202,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello volume: volcello", "long_name": "Moles Per Unit Mass of CFC-11 in sea water", - "comment": "", + "comment": "Mole concentration means number of moles per unit volume, also called 'molarity', and is used in the construction 'mole_concentration_of_X_in_Y', where X is a material constituent of Y. A chemical or biological species denoted by X may be described by a single term such as 'nitrogen' or a phrase such as 'nox_expressed_as_nitrogen'. The chemical formula of CFC11 is CFCl3. The IUPAC name fof CFC11 is trichloro-fluoro-methane.", "dimensions": "longitude latitude olevel time", "out_name": "cfc11", "type": "real", @@ -220,7 +220,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello volume: volcello", "long_name": "Moles Per Unit Mass of CFC-12 in sea water", - "comment": "", + "comment": "Mole concentration means number of moles per unit volume, also called 'molarity', and is used in the construction 'mole_concentration_of_X_in_Y', where X is a material constituent of Y. A chemical or biological species denoted by X may be described by a single term such as 'nitrogen' or a phrase such as 'nox_expressed_as_nitrogen'. The chemical formula for CFC12 is CF2Cl2. The IUPAC name for CFC12 is dichloro-difluoro-methane.", "dimensions": "longitude latitude olevel time", "out_name": "cfc12", "type": "real", @@ -236,10 +236,10 @@ "standard_name": "mass_concentration_of_phytoplankton_expressed_as_chlorophyll_in_sea_water", "units": "kg m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Mass Concentration of Total Chlorophyll in sea water", "comment": "Sum of chlorophyll from all phytoplankton group concentrations. In most models this is equal to chldiat+chlmisc, that is the sum of Diatom Chlorophyll Mass Concentration and Other Phytoplankton Chlorophyll Mass Concentration", - "dimensions": "longitude latitude olevel time", + "dimensions": "longitude latitude time depth0m", "out_name": "chl", "type": "real", "positive": "", @@ -254,10 +254,10 @@ "standard_name": "mass_concentration_of_calcareous_phytoplankton_expressed_as_chlorophyll_in_sea_water", "units": "kg m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Mass Concentration of Calcareous Phytoplankton expressed as Chlorophyll in sea water", "comment": "chlorophyll concentration from the calcite-producing phytoplankton component alone", - "dimensions": "longitude latitude olevel time", + "dimensions": "longitude latitude time depth0m", "out_name": "chlcalc", "type": "real", "positive": "", @@ -275,7 +275,7 @@ "cell_measures": "area: areacello", "long_name": "Surface Mass Concentration of Calcareous Phytoplankton expressed as Chlorophyll in sea water", "comment": "chlorophyll concentration from the calcite-producing phytoplankton component alone", - "dimensions": "longitude latitude time depth0m", + "dimensions": "longitude latitude time", "out_name": "chlcalcos", "type": "real", "positive": "", @@ -290,10 +290,10 @@ "standard_name": "mass_concentration_of_diatoms_expressed_as_chlorophyll_in_sea_water", "units": "kg m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Mass Concentration of Diatom expressed as Chlorophyll in sea water", "comment": "Chlorophyll from diatom phytoplankton component concentration alone", - "dimensions": "longitude latitude olevel time", + "dimensions": "longitude latitude time depth0m", "out_name": "chldiat", "type": "real", "positive": "", @@ -311,7 +311,7 @@ "cell_measures": "area: areacello", "long_name": "Surface Mass Concentration of Diatoms expressed as Chlorophyll in sea water", "comment": "chlorophyll from diatom phytoplankton component concentration alone", - "dimensions": "longitude latitude time depth0m", + "dimensions": "longitude latitude time", "out_name": "chldiatos", "type": "real", "positive": "", @@ -326,10 +326,10 @@ "standard_name": "mass_concentration_of_diazotrophs_expressed_as_chlorophyll_in_sea_water", "units": "kg m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Mass Concentration of Diazotrophs expressed as Chlorophyll in sea water", "comment": "Chlorophyll concentration from the diazotrophic phytoplankton component alone", - "dimensions": "longitude latitude olevel time", + "dimensions": "longitude latitude time depth0m", "out_name": "chldiaz", "type": "real", "positive": "", @@ -347,7 +347,7 @@ "cell_measures": "area: areacello", "long_name": "Surface Mass Concentration of Diazotrophs expressed as Chlorophyll in sea water", "comment": "chlorophyll concentration from the diazotrophic phytoplankton component alone", - "dimensions": "longitude latitude time depth0m", + "dimensions": "longitude latitude time", "out_name": "chldiazos", "type": "real", "positive": "", @@ -362,10 +362,10 @@ "standard_name": "mass_concentration_of_miscellaneous_phytoplankton_expressed_as_chlorophyll_in_sea_water", "units": "kg m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Mass Concentration of Other Phytoplankton expressed as Chlorophyll in sea water", "comment": "Chlorophyll from additional phytoplankton component concentrations alone", - "dimensions": "longitude latitude olevel time", + "dimensions": "longitude latitude time depth0m", "out_name": "chlmisc", "type": "real", "positive": "", @@ -383,7 +383,7 @@ "cell_measures": "area: areacello", "long_name": "Surface Mass Concentration of Other Phytoplankton expressed as Chlorophyll in sea water", "comment": "chlorophyll from additional phytoplankton component concentrations alone", - "dimensions": "longitude latitude time depth0m", + "dimensions": "longitude latitude time", "out_name": "chlmiscos", "type": "real", "positive": "", @@ -401,7 +401,7 @@ "cell_measures": "area: areacello", "long_name": "Surface Mass Concentration of Total Phytoplankton expressed as Chlorophyll in sea water", "comment": "Sum of chlorophyll from all phytoplankton group concentrations at the sea surface. In most models this is equal to chldiat+chlmisc, that is the sum of 'Diatom Chlorophyll Mass Concentration' plus 'Other Phytoplankton Chlorophyll Mass Concentration'", - "dimensions": "longitude latitude time depth0m", + "dimensions": "longitude latitude time", "out_name": "chlos", "type": "real", "positive": "", @@ -416,10 +416,10 @@ "standard_name": "mass_concentration_of_picophytoplankton_expressed_as_chlorophyll_in_sea_water", "units": "kg m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Mass Concentration of Picophytoplankton expressed as Chlorophyll in sea water", "comment": "chlorophyll concentration from the picophytoplankton (<2 um) component alone", - "dimensions": "longitude latitude olevel time", + "dimensions": "longitude latitude time depth0m", "out_name": "chlpico", "type": "real", "positive": "", @@ -437,7 +437,7 @@ "cell_measures": "area: areacello", "long_name": "Surface Mass Concentration of Picophytoplankton expressed as Chlorophyll in sea water", "comment": "chlorophyll concentration from the picophytoplankton (<2 um) component alone", - "dimensions": "longitude latitude time depth0m", + "dimensions": "longitude latitude time", "out_name": "chlpicoos", "type": "real", "positive": "", @@ -452,10 +452,10 @@ "standard_name": "mole_concentration_of_carbonate_expressed_as_carbon_in_sea_water", "units": "mol m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Carbonate ion Concentration", - "comment": "", - "dimensions": "longitude latitude olevel time", + "comment": "'Mole concentration' means number of moles per unit volume, also called'molarity', and is used in the construction mole_concentration_of_X_in_Y, whereX is a material constituent of Y. A chemical or biological species denoted by X may be described by a single term such as 'nitrogen' or a phrase such as 'nox_expressed_as_nitrogen'. The phrase 'expressed_as' is used in the construction A_expressed_as_B, where B is a chemical constituent of A. It means that the quantity indicated by the standard name is calculated solely with respect to the B contained in A, neglecting all other chemical constituents of A. The chemical formula of the carbonate anion is CO3 with a charge of minus two.", + "dimensions": "longitude latitude time depth0m", "out_name": "co3", "type": "real", "positive": "", @@ -470,10 +470,10 @@ "standard_name": "mole_concentration_of_carbonate_abiotic_analogue_expressed_as_carbon_in_sea_water", "units": "mol m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Abiotic Carbonate ion Concentration", - "comment": "", - "dimensions": "longitude latitude olevel time", + "comment": "Mole concentration means number of moles per unit volume, also called 'molarity', and is used in the construction 'mole_concentration_of_X_in_Y', where X is a material constituent of Y. A chemical or biological species denoted by X may be described by a single term such as 'nitrogen' or a phrase such as 'nox_expressed_as_nitrogen'. In ocean biogeochemistry models, an 'abiotic analogue' is used to simulate the effect on a modelled variable when biological effects on ocean carbon concentration and alkalinity are ignored. The phrase 'expressed_as' is used in the construction A_expressed_as_B, where B is a chemical constituent of A. It means that the quantity indicated by the standard name is calculated solely with respect to the B contained in A, neglecting all other chemical constituents of A. The chemical formula of the carbonate anion is CO3 with an electrical charge of minus two.", + "dimensions": "longitude latitude time depth0m", "out_name": "co3abio", "type": "real", "positive": "", @@ -488,10 +488,10 @@ "standard_name": "mole_concentration_of_carbonate_natural_analogue_expressed_as_carbon_in_sea_water", "units": "mol m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Natural Carbonate ion Concentration", - "comment": "", - "dimensions": "longitude latitude olevel time", + "comment": "Mole concentration means number of moles per unit volume, also called 'molarity', and is used in the construction 'mole_concentration_of_X_in_Y', where X is a material constituent of Y. A chemical or biological species denoted by X may be described by a single term such as 'nitrogen' or a phrase such as 'nox_expressed_as_nitrogen'. In ocean biogeochemistry models, a 'natural analogue' is used to simulate the effect on a modelled variable of imposing preindustrial atmospheric carbon dioxide concentrations, even when the model as a whole may be subjected to varying forcings. The phrase 'expressed_as' is used in the construction A_expressed_as_B, where B is a chemical constituent of A. It means that the quantity indicated by the standard name is calculated solely with respect to the B contained in A, neglecting all other chemical constituents of A. The chemical formula of the carbonate anion is CO3 with an electrical charge of minus two.", + "dimensions": "longitude latitude time depth0m", "out_name": "co3nat", "type": "real", "positive": "", @@ -506,10 +506,10 @@ "standard_name": "mole_concentration_of_carbonate_expressed_as_carbon_at_equilibrium_with_pure_aragonite_in_sea_water", "units": "mol m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Carbonate ion Concentration for sea water in equilibrium with pure Aragonite", - "comment": "", - "dimensions": "longitude latitude olevel time", + "comment": "Mole concentration means number of moles per unit volume, also called 'molarity', and is used in the construction 'mole_concentration_of_X_in_Y', where X is a material constituent of Y. A chemical or biological species denoted by X may be described by a single term such as 'nitrogen' or a phrase such as 'nox_expressed_as_nitrogen'. The phrase 'expressed_as' is used in the construction A_expressed_as_B, where B is a chemical constituent of A. It means that the quantity indicated by the standard name is calculated solely with respect to the B contained in A, neglecting all other chemical constituents of A. The chemical formula of the carbonate anion is CO3 with an electrical charge of minus two. Aragonite is a mineral that is a polymorph of calcium carbonate. The chemical formula of aragonite is CaCO3. At a given salinity, the thermodynamic equilibrium is that between dissolved carbonate ion and solid aragonite. Standard names also exist for calcite, another polymorph of calcium carbonate.", + "dimensions": "longitude latitude time depth0m", "out_name": "co3satarag", "type": "real", "positive": "", @@ -524,10 +524,10 @@ "standard_name": "mole_concentration_of_carbonate_expressed_as_carbon_at_equilibrium_with_pure_calcite_in_sea_water", "units": "mol m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Carbonate ion Concentration for sea water in equilibrium with pure Calcite", - "comment": "", - "dimensions": "longitude latitude olevel time", + "comment": "Mole concentration means number of moles per unit volume, also called 'molarity', and is used in the construction 'mole_concentration_of_X_in_Y', where X is a material constituent of Y. A chemical or biological species denoted by X may be described by a single term such as 'nitrogen' or a phrase such as 'nox_expressed_as_nitrogen'. The phrase 'expressed_as' is used in the construction A_expressed_as_B, where B is a chemical constituent of A. It means that the quantity indicated by the standard name is calculated solely with respect to the B contained in A, neglecting all other chemical constituents of A. The chemical formula of the carbonate anion is CO3 with an electrical charge of minus two. Calcite is a mineral that is a polymorph of calcium carbonate. The chemical formula of calcite is CaCO3. At a given salinity, the thermodynamic equilibrium is that between dissolved carbonate ion and solid calcite. Standard names also exist for aragonite, another polymorph of calcium carbonate.", + "dimensions": "longitude latitude time depth0m", "out_name": "co3satcalc", "type": "real", "positive": "", @@ -542,10 +542,10 @@ "standard_name": "mole_concentration_of_organic_detritus_expressed_as_carbon_in_sea_water", "units": "mol m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Detrital Organic Carbon Concentration", "comment": "Sum of detrital organic carbon component concentrations", - "dimensions": "longitude latitude olevel time", + "dimensions": "longitude latitude time depth0m", "out_name": "detoc", "type": "real", "positive": "", @@ -560,10 +560,10 @@ "standard_name": "mole_concentration_of_dissolved_iron_in_sea_water", "units": "mol m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Mole Concentration of Dissolved Iron in sea water", "comment": "Dissolved iron in sea water, including both Fe2+ and Fe3+ ions (but not particulate detrital iron)", - "dimensions": "longitude latitude olevel time", + "dimensions": "longitude latitude time depth0m", "out_name": "dfe", "type": "real", "positive": "", @@ -581,7 +581,7 @@ "cell_measures": "area: areacello", "long_name": "Surface Dissolved Iron Concentration", "comment": "dissolved iron in sea water is meant to include both Fe2+ and Fe3+ ions (but not, e.g., particulate detrital iron)", - "dimensions": "longitude latitude time depth0m", + "dimensions": "longitude latitude time", "out_name": "dfeos", "type": "real", "positive": "", @@ -596,10 +596,10 @@ "standard_name": "mole_concentration_of_dissolved_inorganic_carbon13_in_sea_water", "units": "mol m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Dissolved Inorganic 13Carbon Concentration", "comment": "Dissolved inorganic 14carbon (CO3+HCO3+H2CO3) concentration", - "dimensions": "longitude latitude olevel time", + "dimensions": "longitude latitude time depth0m", "out_name": "dissi13c", "type": "real", "positive": "", @@ -617,7 +617,7 @@ "cell_measures": "area: areacello", "long_name": "Surface Dissolved Inorganic 13Carbon Concentration", "comment": "Dissolved inorganic 14carbon (CO3+HCO3+H2CO3) concentration", - "dimensions": "longitude latitude time depth0m", + "dimensions": "longitude latitude time", "out_name": "dissi13cos", "type": "real", "positive": "", @@ -632,10 +632,10 @@ "standard_name": "mole_concentration_of_dissolved_inorganic_carbon14_in_sea_water", "units": "mol m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Abiotic Dissolved Inorganic 14Carbon Concentration", "comment": "Abiotic Dissolved inorganic 14carbon (CO3+HCO3+H2CO3) concentration", - "dimensions": "longitude latitude olevel time", + "dimensions": "longitude latitude time depth0m", "out_name": "dissi14cabio", "type": "real", "positive": "", @@ -653,7 +653,7 @@ "cell_measures": "area: areacello", "long_name": "Surface Abiotic Dissolved Inorganic 14Carbon Concentration", "comment": "Abiotic Dissolved inorganic 14carbon (CO3+HCO3+H2CO3) concentration", - "dimensions": "longitude latitude time depth0m", + "dimensions": "longitude latitude time", "out_name": "dissi14cabioos", "type": "real", "positive": "", @@ -668,10 +668,10 @@ "standard_name": "mole_concentration_of_dissolved_inorganic_carbon_in_sea_water", "units": "mol m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Dissolved Inorganic Carbon Concentration", "comment": "Dissolved inorganic carbon (CO3+HCO3+H2CO3) concentration", - "dimensions": "longitude latitude olevel time", + "dimensions": "longitude latitude time depth0m", "out_name": "dissic", "type": "real", "positive": "", @@ -686,10 +686,10 @@ "standard_name": "mole_concentration_of_dissolved_inorganic_carbon_abiotic_analogue_in_sea_water", "units": "mol m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Abiotic Dissolved Inorganic Carbon Concentration", "comment": "Abiotic Dissolved inorganic carbon (CO3+HCO3+H2CO3) concentration", - "dimensions": "longitude latitude olevel time", + "dimensions": "longitude latitude time depth0m", "out_name": "dissicabio", "type": "real", "positive": "", @@ -707,7 +707,7 @@ "cell_measures": "area: areacello", "long_name": "Surface Abiotic Dissolved Inorganic Carbon Concentration", "comment": "Abiotic Dissolved inorganic carbon (CO3+HCO3+H2CO3) concentration", - "dimensions": "longitude latitude time depth0m", + "dimensions": "longitude latitude time", "out_name": "dissicabioos", "type": "real", "positive": "", @@ -722,10 +722,10 @@ "standard_name": "mole_concentration_of_dissolved_inorganic_carbon_natural_analogue_in_sea_water", "units": "mol m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Natural Dissolved Inorganic Carbon Concentration", "comment": "Dissolved inorganic carbon (CO3+HCO3+H2CO3) concentration at preindustrial atmospheric xCO2", - "dimensions": "longitude latitude olevel time", + "dimensions": "longitude latitude time depth0m", "out_name": "dissicnat", "type": "real", "positive": "", @@ -743,7 +743,7 @@ "cell_measures": "area: areacello", "long_name": "Surface Natural Dissolved Inorganic Carbon Concentration", "comment": "Dissolved inorganic carbon (CO3+HCO3+H2CO3) concentration at preindustrial atmospheric xCO2", - "dimensions": "longitude latitude time depth0m", + "dimensions": "longitude latitude time", "out_name": "dissicnatos", "type": "real", "positive": "", @@ -758,10 +758,10 @@ "standard_name": "mole_concentration_of_dissolved_organic_carbon_in_sea_water", "units": "mol m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Dissolved Organic Carbon Concentration", "comment": "Sum of dissolved carbon component concentrations explicitly represented (i.e. not ~40 uM refractory unless explicit)", - "dimensions": "longitude latitude olevel time", + "dimensions": "longitude latitude time depth0m", "out_name": "dissoc", "type": "real", "positive": "", @@ -796,8 +796,8 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Surface Mole Concentration of Dimethyl Sulphide in sea water", - "comment": "", - "dimensions": "longitude latitude time depth0m", + "comment": "'Mole concentration' means number of moles per unit volume, also called'molarity', and is used in the construction mole_concentration_of_X_in_Y, whereX is a material constituent of Y. A chemical or biological species denoted by X may be described by a single term such as 'nitrogen' or a phrase such as 'nox_expressed_as_nitrogen'. The chemical formula for dimethyl sulfide is (CH3)2S. Dimethyl sulfide is sometimes referred to as DMS.", + "dimensions": "longitude latitude time", "out_name": "dmsos", "type": "real", "positive": "", @@ -814,7 +814,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Delta PCO2", - "comment": "", + "comment": "The partial pressure of a dissolved gas in sea water is the partial pressure in air with which it would be in equilibrium. The partial pressure of a gaseous constituent of air is the pressure which it alone would exert with unchanged temperature and number of moles per unit volume. The surface called 'surface' means the lower boundary of the atmosphere. The chemical formula for carbon dioxide is CO2.", "dimensions": "longitude latitude time depth0m", "out_name": "dpco2", "type": "real", @@ -832,7 +832,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Abiotic Delta PCO2", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. The chemical formula for carbon dioxide is CO2. In ocean biogeochemistry models, an 'abiotic analogue' is used to simulate the effect on a modelled variable when biological effects on ocean carbon concentration and alkalinity are ignored. The partial pressure of a gaseous constituent of air is the pressure which it alone would exert with unchanged temperature and number of moles per unit volume. The partial pressure of a dissolved gas in sea water is the partial pressure in air with which it would be in equilibrium. The partial pressure difference between sea water and air is positive when the partial pressure of the dissolved gas in sea water is greater than the partial pressure in air.", "dimensions": "longitude latitude time depth0m", "out_name": "dpco2abio", "type": "real", @@ -850,7 +850,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Natural Delta PCO2", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. The chemical formula for carbon dioxide is CO2. In ocean biogeochemistry models, a 'natural analogue' is used to simulate the effect on a modelled variable of imposing preindustrial atmospheric carbon dioxide concentrations, even when the model as a whole may be subjected to varying forcings. The partial pressure of a gaseous constituent of air is the pressure which it alone would exert with unchanged temperature and number of moles per unit volume. The partial pressure of a dissolved gas in sea water is the partial pressure in air with which it would be in equilibrium. The partial pressure difference between sea water and air is positive when the partial pressure of the dissolved gas in sea water is greater than the partial pressure in air.", "dimensions": "longitude latitude time depth0m", "out_name": "dpco2nat", "type": "real", @@ -868,7 +868,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Delta PO2", - "comment": "", + "comment": "The partial pressure of a dissolved gas in sea water is the partial pressure in air with which it would be in equilibrium. The partial pressure of a gaseous constituent of air is the pressure which it alone would exert with unchanged temperature and number of moles per unit volume. The surface called 'surface' means the lower boundary of the atmosphere.", "dimensions": "longitude latitude time depth0m", "out_name": "dpo2", "type": "real", @@ -886,7 +886,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Downward Flux of Aragonite", - "comment": "", + "comment": "The phrase 'expressed_as' is used in the construction A_expressed_as_B, where B is a chemical constituent of A. It means that the quantity indicated by the standard name is calculated solely with respect to the B contained in A, neglecting all other chemical constituents of A. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics. 'Sinking' is the gravitational settling of particulate matter suspended in a liquid. A sinking flux is positive downwards and is calculated relative to the movement of the surrounding fluid. Aragonite is a mineral that is a polymorph of calcium carbonate. The chemical formula of aragonite is CaCO3. Standard names also exist for calcite, another polymorph of calcium carbonate.", "dimensions": "longitude latitude time depth100m", "out_name": "eparag100", "type": "real", @@ -904,7 +904,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Downward Flux of Particle Organic Carbon", - "comment": "", + "comment": "The phrase 'expressed_as' is used in the construction A_expressed_as_B, where B is a chemical constituent of A. It means that the quantity indicated by the standard name is calculated solely with respect to the B contained in A, neglecting all other chemical constituents of A. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics. 'Sinking' is the gravitational settling of particulate matter suspended in a liquid. A sinking flux is positive downwards and is calculated relative to the movement of the surrounding fluid.", "dimensions": "longitude latitude time depth100m", "out_name": "epc100", "type": "real", @@ -922,7 +922,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Downward Flux of Calcite", - "comment": "", + "comment": "The phrase 'expressed_as' is used in the construction A_expressed_as_B, where B is a chemical constituent of A. It means that the quantity indicated by the standard name is calculated solely with respect to the B contained in A, neglecting all other chemical constituents of A. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics. 'Sinking' is the gravitational settling of particulate matter suspended in a liquid. A sinking flux is positive downwards and is calculated relative to the movement of the surrounding fluid. Calcite is a mineral that is a polymorph of calcium carbonate. The chemical formula of calcite is CaCO3. Standard names also exist for aragonite, another polymorph of calcium carbonate.", "dimensions": "longitude latitude time depth100m", "out_name": "epcalc100", "type": "real", @@ -940,7 +940,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Downward Flux of Particulate Iron", - "comment": "", + "comment": "In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics. 'Sinking' is the gravitational settling of particulate matter suspended in a liquid. A sinking flux is positive downwards and is calculated relative to the movement of the surrounding fluid.", "dimensions": "longitude latitude time depth100m", "out_name": "epfe100", "type": "real", @@ -958,7 +958,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Downward Flux of Particulate Nitrogen", - "comment": "", + "comment": "In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics. 'Sinking' is the gravitational settling of particulate matter suspended in a liquid. A sinking flux is positive downwards and is calculated relative to the movement of the surrounding fluid.", "dimensions": "longitude latitude time depth100m", "out_name": "epn100", "type": "real", @@ -976,7 +976,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Downward Flux of Particulate Phosphorus", - "comment": "", + "comment": "In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics. 'Sinking' is the gravitational settling of particulate matter suspended in a liquid. A sinking flux is positive downwards and is calculated relative to the movement of the surrounding fluid.", "dimensions": "longitude latitude time depth100m", "out_name": "epp100", "type": "real", @@ -994,7 +994,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Downward Flux of Particulate Silica", - "comment": "", + "comment": "In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics. 'Sinking' is the gravitational settling of particulate matter suspended in a liquid. A sinking flux is positive downwards and is calculated relative to the movement of the surrounding fluid.", "dimensions": "longitude latitude time depth100m", "out_name": "epsi100", "type": "real", @@ -1174,7 +1174,7 @@ "cell_methods": "area: mean where sea depth: sum where sea (top 100m only) time: mean", "cell_measures": "area: areacello", "long_name": "Rate of Change of Net Dissolved Inorganic Carbon", - "comment": "", + "comment": "'Content' indicates a quantity per unit area. 'tendency_of_X' means derivative of X with respect to time. 'Dissolved inorganic carbon' describes a family of chemical species in solution, including carbon dioxide, carbonic acid and the carbonate and bicarbonate anions. 'Dissolved inorganic carbon' isthe term used in standard names for all species belonging to the family that are represented within a given model. The list of individual species that are included in a quantity having a group chemical standard name can vary between models. Where possible, the data variable should be accompanied by a complete description of the species represented, for example, by using a comment attribute.", "dimensions": "longitude latitude time olayer100m", "out_name": "fddtdic", "type": "real", @@ -1264,7 +1264,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Surface Downward Flux of Abiotic 13CO2", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'Downward' indicates a vector component which is positive when directed downward (negative upward). In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics. In ocean biogeochemistry models, an 'abiotic analogue' is used to simulate the effect on a modelled variable when biological effects on ocean carbon concentration and alkalinity are ignored. The phrase 'expressed_as' is used in the construction A_expressed_as_B, where B is a chemical constituent of A. It means that the quantity indicated by the standard name is calculated solely with respect to the B contained in A, neglecting all other chemical constituents of A. Carbon13 is a stable isotope of carbon having six protons and seven neutrons.", "dimensions": "longitude latitude time depth0m", "out_name": "fg13co2", "type": "real", @@ -1480,7 +1480,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Iron Loss to Sediments", - "comment": "", + "comment": "'Content' indicates a quantity per unit area. The specification of a physical process by the phrase due_to_process means that the quantity named is a single term in a sum of terms which together compose the general quantity named by omitting the phrase. 'tendency_of_X' means derivative of X with respect to time.", "dimensions": "longitude latitude time", "out_name": "frfe", "type": "real", @@ -1534,7 +1534,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Nitrogen Loss to Sediments and through Denitrification", - "comment": "", + "comment": "'Content' indicates a quantity per unit area. The specification of a physical process by the phrase due_to_process means that the quantity named is asingle term in a sum of terms which together compose the general quantity named by omitting the phrase. 'Denitrification' is the conversion of nitrate into gasesous compounds such as nitric oxide, nitrous oxide and molecular nitrogen which are then emitted to the atmosphere. 'Sedimentation' is the sinking of particulate matter to the floor of a body of water. 'tendency_of_X' means derivative of X with respect to time.", "dimensions": "longitude latitude time", "out_name": "frn", "type": "real", @@ -1606,7 +1606,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Surface Downward Net Flux of Nitrogen", - "comment": "", + "comment": "'Content' indicates a quantity per unit area. The specification of a physical process by the phrase due_to_process means that the quantity named is asingle term in a sum of terms which together compose the general quantity named by omitting the phrase. Deposition of nitrogen into the ocean is the sum of dry and wet depositionof nitrogen species onto the ocean surface from the atmosphere. 'Nitrogen fixation' means the production of ammonia from nitrogen gas. Organisms that fix nitrogen are termed 'diazotrophs'. Diazotrophic phytoplankton can fix atmospheric nitrogen, thus increasing the content of nitrogen in the ocean. Runoff is the liquid water which drains from land. If not specified, 'runoff' refers to the sum of surface runoff and subsurface drainage.'tendency_of_X' means derivative of X with respect to time.", "dimensions": "longitude latitude time depth0m", "out_name": "fsn", "type": "real", @@ -1624,7 +1624,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello volume: volcello", "long_name": "Total Grazing of Phytoplankton by Zooplankton", - "comment": "", + "comment": "'tendency_of_X' means derivative of X with respect to time. Mole concentration means number of moles per unit volume, also called 'molarity', and is used in the construction 'mole_concentration_of_X_in_Y', where X is a material constituent of Y. A chemical or biological species denoted by X may be described by a single term such as 'nitrogen' or a phrase such as 'nox_expressed_as_nitrogen'. The phrase 'expressed_as' is used in the construction A_expressed_as_B, where B is a chemical constituent of A. It means that the quantity indicated by the standard name is calculated solely with respect to the B contained in A, neglecting all other chemical constituents of A. The specification of a physical process by the phrase 'due_to_' process means that the quantity named is a single term in a sum of terms which together compose the general quantity named by omitting the phrase.", "dimensions": "longitude latitude olevel time", "out_name": "graz", "type": "real", @@ -1732,7 +1732,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Heat Flux Correction", - "comment": "", + "comment": "Flux correction is also called 'flux adjustment'. A positive flux correction is downward i.e. added to the ocean. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "longitude latitude time", "out_name": "hfcorr", "type": "real", @@ -1786,7 +1786,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Upward Geothermal Heat Flux at Sea Floor", - "comment": "", + "comment": "'Upward' indicates a vector component which is positive when directed upward (negative downward). In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "longitude latitude time", "out_name": "hfgeou", "type": "real", @@ -1804,7 +1804,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello volume: volcello", "long_name": "Heat Flux into Sea Water due to Iceberg Thermodynamics", - "comment": "", + "comment": "In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics. The specification of a physical process by the phrase due_to_process means that the quantity named is a single term in a sum of terms which together compose the general quantity named by omitting the phrase. ' Iceberg thermodynamics' refers to the addition or subtraction of mass due to surface and basal fluxes, i.e., due to melting, sublimation and fusion.", "dimensions": "longitude latitude olevel time", "out_name": "hfibthermds", "type": "real", @@ -1822,7 +1822,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Heat Flux into Sea Water due to Iceberg Thermodynamics", - "comment": "", + "comment": "In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics. The specification of a physical process by the phrase due_to_process means that the quantity named is a single term in a sum of terms which together compose the general quantity named by omitting the phrase. ' Iceberg thermodynamics' refers to the addition or subtraction of mass due to surface and basal fluxes, i.e., due to melting, sublimation and fusion.", "dimensions": "longitude latitude time", "out_name": "hfibthermds", "type": "real", @@ -1876,7 +1876,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello volume: volcello", "long_name": "Temperature Flux due to Runoff Expressed as Heat Flux into Sea Water", - "comment": "", + "comment": "Runoff is the liquid water which drains from land. If not specified, 'runoff' refers to the sum of surface runoff and subsurface drainage. The quantity with standard name temperature_flux_due_to_runoff_expressed_as_heat_flux_into_sea_water is the heat carried by the transfer of water into the liquid ocean by the process of runoff. This quantity additonally includes melt water from sea ice and icebergs. It is calculated relative to the heat that would be transported by runoff water entering the sea at zero degrees Celsius. It is calculated as the product QrunoffCpTrunoff, where Q runoff is the mass flux of liquid runoff entering the sea water (kg m-2 s-1), Cp is the specific heat capacity of water, and Trunoff is the temperature in degrees Celsius of the runoff water. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "longitude latitude olevel time", "out_name": "hfrunoffds", "type": "real", @@ -1894,7 +1894,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Temperature Flux due to Runoff Expressed as Heat Flux into Sea Water", - "comment": "", + "comment": "Runoff is the liquid water which drains from land. If not specified, 'runoff' refers to the sum of surface runoff and subsurface drainage. The quantity with standard name temperature_flux_due_to_runoff_expressed_as_heat_flux_into_sea_water is the heat carried by the transfer of water into the liquid ocean by the process of runoff. This quantity additonally includes melt water from sea ice and icebergs. It is calculated relative to the heat that would be transported by runoff water entering the sea at zero degrees Celsius. It is calculated as the product QrunoffCpTrunoff, where Q runoff is the mass flux of liquid runoff entering the sea water (kg m-2 s-1), Cp is the specific heat capacity of water, and Trunoff is the temperature in degrees Celsius of the runoff water. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "longitude latitude time", "out_name": "hfrunoffds", "type": "real", @@ -1912,7 +1912,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello volume: volcello", "long_name": "Heat Flux into Sea Water due to Frazil Ice Formation", - "comment": "", + "comment": "In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics. The specification of a physical process by the phrase due_to_process means that the quantity named is a single term in a sum of terms which together compose the general quantity named by omitting the phrase. 'Frazil' consists of needle like crystals of ice, typically between three and four millimeters in diameter, which form as sea water begins to freeze. Salt is expelled during the freezing process and frazil ice consists of nearly pure fresh water.", "dimensions": "longitude latitude olevel time", "out_name": "hfsifrazil", "type": "real", @@ -1930,7 +1930,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Heat Flux into Sea Water due to Frazil Ice Formation", - "comment": "", + "comment": "In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics. The specification of a physical process by the phrase due_to_process means that the quantity named is a single term in a sum of terms which together compose the general quantity named by omitting the phrase. 'Frazil' consists of needle like crystals of ice, typically between three and four millimeters in diameter, which form as sea water begins to freeze. Salt is expelled during the freezing process and frazil ice consists of nearly pure fresh water.", "dimensions": "longitude latitude time", "out_name": "hfsifrazil", "type": "real", @@ -1948,7 +1948,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello volume: volcello", "long_name": "Heat Flux into Sea Water due to Snow Thermodynamics", - "comment": "", + "comment": "In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics. The specification of a physical process by the phrase due_to_process means that the quantity named is a single term in a sum of terms which together compose the general quantity named by omitting the phrase. 'Snow thermodynamics' refers to the addition or subtraction of mass due to surface and basal fluxes, i.e., due to melting, sublimation and fusion.", "dimensions": "longitude latitude olevel time", "out_name": "hfsnthermds", "type": "real", @@ -1966,7 +1966,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Heat Flux into Sea Water due to Snow Thermodynamics", - "comment": "", + "comment": "In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics. The specification of a physical process by the phrase due_to_process means that the quantity named is a single term in a sum of terms which together compose the general quantity named by omitting the phrase. 'Snow thermodynamics' refers to the addition or subtraction of mass due to surface and basal fluxes, i.e., due to melting, sublimation and fusion.", "dimensions": "longitude latitude time", "out_name": "hfsnthermds", "type": "real", @@ -2089,7 +2089,7 @@ "modeling_realm": "ocnBgChem", "standard_name": "ocean_mass_content_of_dissolved_inorganic_carbon", "units": "kg m-2", - "cell_methods": "area: mean where sea time: mean", + "cell_methods": "area: mean where sea depth: sum where sea time: mean", "cell_measures": "area: areacello", "long_name": "Dissolved Inorganic Carbon Content", "comment": "Vertically integrated DIC", @@ -2107,7 +2107,7 @@ "modeling_realm": "ocnBgChem", "standard_name": "ocean_mass_content_of_dissolved_organic_carbon", "units": "kg m-2", - "cell_methods": "area: mean where sea time: mean", + "cell_methods": "area: mean where sea depth: sum where sea time: mean", "cell_measures": "area: areacello", "long_name": "Dissolved Organic Carbon Content", "comment": "Vertically integrated DOC (explicit pools only)", @@ -2125,7 +2125,7 @@ "modeling_realm": "ocnBgChem", "standard_name": "tendency_of_ocean_mole_content_of_aragonite_expressed_as_carbon_due_to_biological_production", "units": "mol m-2 s-1", - "cell_methods": "area: mean where sea time: mean", + "cell_methods": "area: mean where sea depth: sum where sea time: mean", "cell_measures": "area: areacello", "long_name": "Aragonite Production", "comment": "Vertically integrated aragonite production", @@ -2143,7 +2143,7 @@ "modeling_realm": "ocnBgChem", "standard_name": "tendency_of_ocean_mole_content_of_iron_due_to_biological_production", "units": "mol m-2 s-1", - "cell_methods": "area: mean where sea time: mean", + "cell_methods": "area: mean where sea depth: sum where sea time: mean", "cell_measures": "area: areacello", "long_name": "Iron Production", "comment": "Vertically integrated biogenic iron production", @@ -2161,7 +2161,7 @@ "modeling_realm": "ocnBgChem", "standard_name": "tendency_of_ocean_mole_content_of_nitrogen_due_to_biological_production", "units": "mol m-2 s-1", - "cell_methods": "area: mean where sea time: mean", + "cell_methods": "area: mean where sea depth: sum where sea time: mean", "cell_measures": "area: areacello", "long_name": "Nitrogen Production", "comment": "Vertically integrated biogenic nitrogen production", @@ -2179,7 +2179,7 @@ "modeling_realm": "ocnBgChem", "standard_name": "tendency_of_ocean_mole_content_of_phosphorus_due_to_biological_production", "units": "mol m-2 s-1", - "cell_methods": "area: mean where sea time: mean", + "cell_methods": "area: mean where sea depth: sum where sea time: mean", "cell_measures": "area: areacello", "long_name": "Phosphorus Production", "comment": "Vertically integrated biogenic phosphorus production", @@ -2197,7 +2197,7 @@ "modeling_realm": "ocnBgChem", "standard_name": "tendency_of_ocean_mole_content_of_silicon_due_to_biological_production", "units": "mol m-2 s-1", - "cell_methods": "area: mean where sea time: mean", + "cell_methods": "area: mean where sea depth: sum where sea time: mean", "cell_measures": "area: areacello", "long_name": "Silica Production", "comment": "Vertically integrated biogenic silica production", @@ -2215,7 +2215,7 @@ "modeling_realm": "ocnBgChem", "standard_name": "tendency_of_ocean_mole_content_of_calcite_expressed_as_carbon_due_to_biological_production", "units": "mol m-2 s-1", - "cell_methods": "area: mean where sea time: mean", + "cell_methods": "area: mean where sea depth: sum where sea time: mean", "cell_measures": "area: areacello", "long_name": "Calcite Production", "comment": "Vertically integrated calcite production", @@ -2233,7 +2233,7 @@ "modeling_realm": "ocnBgChem", "standard_name": "tendency_of_ocean_mole_content_of_elemental_nitrogen_due_to_fixation", "units": "mol m-2 s-1", - "cell_methods": "area: mean where sea time: mean", + "cell_methods": "area: mean where sea depth: sum where sea time: mean", "cell_measures": "area: areacello", "long_name": "Nitrogen Fixation Rate in Ocean", "comment": "Vertically integrated nitrogen fixation", @@ -2251,7 +2251,7 @@ "modeling_realm": "ocnBgChem", "standard_name": "ocean_mass_content_of_particulate_organic_matter_expressed_as_carbon", "units": "kg m-2", - "cell_methods": "area: mean where sea time: mean", + "cell_methods": "area: mean where sea depth: sum where sea time: mean", "cell_measures": "area: areacello", "long_name": "Particulate Organic Carbon Content", "comment": "Vertically integrated POC", @@ -2269,7 +2269,7 @@ "modeling_realm": "ocnBgChem", "standard_name": "net_primary_mole_productivity_of_biomass_expressed_as_carbon_by_phytoplankton", "units": "mol m-2 s-1", - "cell_methods": "area: mean where sea time: mean", + "cell_methods": "area: mean where sea depth: sum where sea time: mean", "cell_measures": "area: areacello", "long_name": "Primary Organic Carbon Production by All Types of Phytoplankton", "comment": "Vertically integrated total primary (organic carbon) production by phytoplankton. This should equal the sum of intpdiat+intpphymisc, but those individual components may be unavailable in some models.", @@ -2287,10 +2287,10 @@ "modeling_realm": "ocnBgChem", "standard_name": "net_primary_mole_productivity_of_biomass_expressed_as_carbon_by_calcareous_phytoplankton", "units": "mol m-2 s-1", - "cell_methods": "area: mean where sea time: mean", + "cell_methods": "area: mean where sea depth: sum where sea time: mean", "cell_measures": "area: areacello", "long_name": "Net Primary Mole Productivity of Carbon by Calcareous Phytoplankton", - "comment": "", + "comment": "'Production of carbon' means the production of biomass expressed as the mass of carbon which it contains. Net primary production is the excess of gross primary production (rate of synthesis of biomass from inorganic precursors) by autotrophs ('producers'), for example, photosynthesis in plants or phytoplankton, over the rate at which the autotrophs themselves respire some of this biomass. 'Productivity' means production per unit area. Phytoplankton are autotrophic prokaryotic or eukaryotic algae that live near the water surface where there is sufficient light to support photosynthesis. 'Calcareous phytoplankton' are phytoplankton that produce calcite. The phrase 'expressed_as' is used in the construction A_expressed_as_B, where B is a chemical constituent of A. It means that the quantity indicated by the standard name is calculated solely with respect to the B contained in A, neglecting all other chemical constituents of A. Calcite is a mineral that is a polymorph of calcium carbonate.", "dimensions": "longitude latitude time", "out_name": "intppcalc", "type": "real", @@ -2305,7 +2305,7 @@ "modeling_realm": "ocnBgChem", "standard_name": "net_primary_mole_productivity_of_biomass_expressed_as_carbon_by_diatoms", "units": "mol m-2 s-1", - "cell_methods": "area: mean where sea time: mean", + "cell_methods": "area: mean where sea depth: sum where sea time: mean", "cell_measures": "area: areacello", "long_name": "Net Primary Organic Carbon Production by Diatoms", "comment": "Vertically integrated primary (organic carbon) production by the diatom phytoplankton component alone", @@ -2323,10 +2323,10 @@ "modeling_realm": "ocnBgChem", "standard_name": "net_primary_mole_productivity_of_biomass_expressed_as_carbon_by_diazotrophs", "units": "mol m-2 s-1", - "cell_methods": "area: mean where sea time: mean", + "cell_methods": "area: mean where sea depth: sum where sea time: mean", "cell_measures": "area: areacello", "long_name": "Net Primary Mole Productivity of Carbon by Diazotrophs", - "comment": "", + "comment": "'Production of carbon' means the production of biomass expressed as the mass of carbon which it contains. Net primary production is the excess of gross primary production (rate of synthesis of biomass from inorganic precursors) by autotrophs ('producers'), for example, photosynthesis in plants or phytoplankton, over the rate at which the autotrophs themselves respire some of this biomass. 'Productivity' means production per unit area. In ocean modelling, diazotrophs are phytoplankton of the phylum cyanobacteria distinct from other phytoplankton groups in their ability to fix nitrogen gas in addition to nitrate and ammonium. Phytoplankton are autotrophic prokaryotic or eukaryotic algae that live near the water surface where there is sufficient light to support photosynthesis. The phrase 'expressed_as' is used in the construction A_expressed_as_B, where B is a chemical constituent of A.", "dimensions": "longitude latitude time", "out_name": "intppdiaz", "type": "real", @@ -2341,7 +2341,7 @@ "modeling_realm": "ocnBgChem", "standard_name": "net_primary_mole_productivity_of_biomass_expressed_as_carbon_by_miscellaneous_phytoplankton", "units": "mol m-2 s-1", - "cell_methods": "area: mean where sea time: mean", + "cell_methods": "area: mean where sea depth: sum where sea time: mean", "cell_measures": "area: areacello", "long_name": "Net Primary Organic Carbon Production by Other Phytoplankton", "comment": "Vertically integrated total primary (organic carbon) production by other phytoplankton components alone", @@ -2359,7 +2359,7 @@ "modeling_realm": "ocnBgChem", "standard_name": "net_primary_mole_productivity_of_biomass_expressed_as_carbon_due_to_nitrate_utilization", "units": "mol m-2 s-1", - "cell_methods": "area: mean where sea time: mean", + "cell_methods": "area: mean where sea depth: sum where sea time: mean", "cell_measures": "area: areacello", "long_name": "Primary Organic Carbon Production by Phytoplankton Based on Nitrate Uptake Alone", "comment": "Vertically integrated primary (organic carbon) production by phytoplankton based on nitrate uptake alone", @@ -2377,10 +2377,10 @@ "modeling_realm": "ocnBgChem", "standard_name": "net_primary_mole_productivity_of_biomass_expressed_as_carbon_by_picophytoplankton", "units": "mol m-2 s-1", - "cell_methods": "area: mean where sea time: mean", + "cell_methods": "area: mean where sea depth: sum where sea time: mean", "cell_measures": "area: areacello", "long_name": "Net Primary Mole Productivity of Carbon by Picophytoplankton", - "comment": "", + "comment": "'Production of carbon' means the production of biomass expressed as the mass of carbon which it contains. Net primary production is the excess of gross primary production (rate of synthesis of biomass from inorganic precursors) by autotrophs ('producers'), for example, photosynthesis in plants or phytoplankton, over the rate at which the autotrophs themselves respire some of this biomass. 'Productivity' means production per unit area. Picophytoplankton are phytoplankton of less than 2 micrometers in size. Phytoplankton are autotrophic prokaryotic or eukaryotic algae that live near the water surface where there is sufficient light to support photosynthesis. The phrase 'expressed_as' is used in the construction A_expressed_as_B, where B is a chemical constituent of A. It means that the quantity indicated by the standard name is calculated solely with respect to the B contained in A, neglecting all other chemical constituents of A.", "dimensions": "longitude latitude time", "out_name": "intpppico", "type": "real", @@ -2398,7 +2398,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Iron limitation of Calcareous Phytoplankton", - "comment": "", + "comment": "'Calcareous phytoplankton' are phytoplankton that produce calcite. Calcite is a mineral that is a polymorph of calcium carbonate. The chemical formula of calcite is CaCO3. Phytoplankton are algae that grow where there is sufficient light to support photosynthesis. 'Iron growth limitation' means the ratio of the growth rate of a species population in the environment (where there is a finite availability of iron) to the theoretical growth rate if there were no such limit on iron availability.", "dimensions": "longitude latitude time", "out_name": "limfecalc", "type": "real", @@ -2416,7 +2416,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Iron limitation of Diatoms", - "comment": "", + "comment": "Diatoms are phytoplankton with an external skeleton made of silica. Phytoplankton are algae that grow where there is sufficient light to support photosynthesis. 'Iron growth limitation' means the ratio of the growth rate of a species population in the environment (where there is a finite availability of iron) to the theoretical growth rate if there were no such limit on iron availability.", "dimensions": "longitude latitude time", "out_name": "limfediat", "type": "real", @@ -2434,7 +2434,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Iron limitation of Diazotrophs", - "comment": "", + "comment": "In ocean modelling, diazotrophs are phytoplankton of the phylum cyanobacteria distinct from other phytoplankton groups in their ability to fix nitrogen gas in addition to nitrate and ammonium. Phytoplankton are algae that grow where there is sufficient light to support photosynthesis. 'Iron growth limitation' means the ratio of the growth rate of a species population in the environment (where there is a finite availability of iron) to the theoretical growth rate if there were no such limit on iron availability.", "dimensions": "longitude latitude time", "out_name": "limfediaz", "type": "real", @@ -2452,7 +2452,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Iron Limitation of Other Phytoplankton", - "comment": "", + "comment": "Phytoplankton are algae that grow where there is sufficient light to support photosynthesis. 'Miscellaneous phytoplankton' are all those phytoplankton that are not diatoms, diazotrophs, calcareous phytoplankton, picophytoplankton or other separately named components of the phytoplankton population. 'Iron growth limitation' means the ratio of the growth rate of a species population in the environment (where there is a finite availability of iron) to the theoretical growth rate if there were no such limit on iron availability.", "dimensions": "longitude latitude time", "out_name": "limfemisc", "type": "real", @@ -2470,7 +2470,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Iron limitation of Picophytoplankton", - "comment": "", + "comment": "Picophytoplankton are phytoplankton of less than 2 micrometers in size. Phytoplankton are algae that grow where there is sufficient light to support photosynthesis. 'Iron growth limitation' means the ratio of the growth rate of a species population in the environment (where there is a finite availability of iron) to the theoretical growth rate if there were no such limit on iron availability.", "dimensions": "longitude latitude time", "out_name": "limfepico", "type": "real", @@ -2488,7 +2488,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Irradiance limitation of Calcareous Phytoplankton", - "comment": "", + "comment": "'Calcareous phytoplankton' are phytoplankton that produce calcite. Calcite is a mineral that is a polymorph of calcium carbonate. The chemical formula of calcite is CaCO3. Phytoplankton are algae that grow where there is sufficient light to support photosynthesis. The specification of a physical process by the phrase 'due_to_' process means that the quantity named is a single term in a sum of terms which together compose the general quantity named by omitting the phrase. 'Irradiance' means the power per unit area (called radiative flux in other standard names), the area being normal to the direction of flow of the radiant energy. Solar irradiance is essential to the photosynthesis reaction and its presence promotes the growth of phytoplankton populations.", "dimensions": "longitude latitude time", "out_name": "limirrcalc", "type": "real", @@ -2506,7 +2506,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Irradiance limitation of Diatoms", - "comment": "", + "comment": "Diatoms are phytoplankton with an external skeleton made of silica. Phytoplankton are algae that grow where there is sufficient light to support photosynthesis. The specification of a physical process by the phrase 'due_to_' process means that the quantity named is a single term in a sum of terms which together compose the general quantity named by omitting the phrase. 'Irradiance' means the power per unit area (called radiative flux in other standard names), the area being normal to the direction of flow of the radiant energy. Solar irradiance is essential to the photosynthesis reaction and its presence promotes the growth of phytoplankton populations. 'Growth limitation due to solar irradiance' means the ratio of the growth rate of a species population in the environment (where the amount of sunlight reaching a location may be limited) to the theoretical growth rate if there were no such limit on solar irradiance.", "dimensions": "longitude latitude time", "out_name": "limirrdiat", "type": "real", @@ -2524,7 +2524,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Irradiance limitation of Diazotrophs", - "comment": "", + "comment": "In ocean modelling, diazotrophs are phytoplankton of the phylum cyanobacteria distinct from other phytoplankton groups in their ability to fix nitrogen gas in addition to nitrate and ammonium. Phytoplankton are algae that grow where there is sufficient light to support photosynthesis. The specification of a physical process by the phrase 'due_to_' process means that the quantity named is a single term in a sum of terms which together compose the general quantity named by omitting the phrase. 'Irradiance' means the power per unit area (called radiative flux in other standard names), the area being normal to the direction of flow of the radiant energy. Solar irradiance is essential to the photosynthesis reaction and its presence promotes the growth of phytoplankton populations.", "dimensions": "longitude latitude time", "out_name": "limirrdiaz", "type": "real", @@ -2542,7 +2542,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Irradiance Limitation of Other Phytoplankton", - "comment": "", + "comment": "Phytoplankton are algae that grow where there is sufficient light to support photosynthesis. 'Miscellaneous phytoplankton' are all those phytoplankton that are not diatoms, diazotrophs, calcareous phytoplankton, picophytoplankton or other separately named components of the phytoplankton population. The specification of a physical process by the phrase 'due_to_' process means that the quantity named is a single term in a sum of terms which together compose the general quantity named by omitting the phrase. 'Irradiance' means the power per unit area (called radiative flux in other standard names), the area being normal to the direction of flow of the radiant energy. Solar irradiance is essential to the photosynthesis reaction and its presence promotes the growth of phytoplankton populations.", "dimensions": "longitude latitude time", "out_name": "limirrmisc", "type": "real", @@ -2560,7 +2560,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Irradiance limitation of Picophytoplankton", - "comment": "", + "comment": "Picophytoplankton are phytoplankton of less than 2 micrometers in size. Phytoplankton are algae that grow where there is sufficient light to support photosynthesis. The specification of a physical process by the phrase 'due_to_' process means that the quantity named is a single term in a sum of terms which together compose the general quantity named by omitting the phrase. 'Irradiance' means the power per unit area (called radiative flux in other standard names), the area being normal to the direction of flow of the radiant energy. Solar irradiance is essential to the photosynthesis reaction and its presence promotes the growth of phytoplankton populations. 'Growth limitation due to solar irradiance' means the ratio of the growth rate of a species population in the environment (where the amount of sunlight reaching a location may be limited) to the theoretical growth rate if there were no such limit on solar irradiance.", "dimensions": "longitude latitude time", "out_name": "limirrpico", "type": "real", @@ -2578,7 +2578,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Nitrogen limitation of Calcareous Phytoplankton", - "comment": "", + "comment": "'Calcareous phytoplankton' are phytoplankton that produce calcite. Calcite is a mineral that is a polymorph of calcium carbonate. The chemical formula of calcite is CaCO3. Phytoplankton are algae that grow where there is sufficient light to support photosynthesis. 'Nitrogen growth limitation' means the ratio of the growth rate of a species population in the environment (where there is a finite availability of nitrogen) to the theoretical growth rate if there were no such limit on nitrogen availability.", "dimensions": "longitude latitude time", "out_name": "limncalc", "type": "real", @@ -2596,7 +2596,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Nitrogen limitation of Diatoms", - "comment": "", + "comment": "Diatoms are phytoplankton with an external skeleton made of silica. Phytoplankton are algae that grow where there is sufficient light to support photosynthesis. 'Nitrogen growth limitation' means the ratio of the growth rate of a species population in the environment (where there is a finite availability of nitrogen) to the theoretical growth rate if there were no such limit on nitrogen availability.", "dimensions": "longitude latitude time", "out_name": "limndiat", "type": "real", @@ -2614,7 +2614,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Nitrogen limitation of Diazotrophs", - "comment": "", + "comment": "In ocean modelling, diazotrophs are phytoplankton of the phylum cyanobacteria distinct from other phytoplankton groups in their ability to fix nitrogen gas in addition to nitrate and ammonium. Phytoplankton are algae that grow where there is sufficient light to support photosynthesis. 'Nitrogen growth limitation' means the ratio of the growth rate of a species population in the environment (where there is a finite availability of nitrogen) to the theoretical growth rate if there were no such limit on nitrogen availability.", "dimensions": "longitude latitude time", "out_name": "limndiaz", "type": "real", @@ -2632,7 +2632,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Nitrogen Limitation of Other Phytoplankton", - "comment": "", + "comment": "Phytoplankton are algae that grow where there is sufficient light to support photosynthesis. 'Miscellaneous phytoplankton' are all those phytoplankton that are not diatoms, diazotrophs, calcareous phytoplankton, picophytoplankton or other separately named components of the phytoplankton population. 'Nitrogen growth limitation' means the ratio of the growth rate of a species population in the environment (where there is a finite availability of nitrogen) to the theoretical growth rate if there were no such limit on nitrogen availability.", "dimensions": "longitude latitude time", "out_name": "limnmisc", "type": "real", @@ -2650,7 +2650,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Nitrogen limitation of Picophytoplankton", - "comment": "", + "comment": "Picophytoplankton are phytoplankton of less than 2 micrometers in size. Phytoplankton are algae that grow where there is sufficient light to support photosynthesis. 'Nitrogen growth limitation' means the ratio of the growth rate of a species population in the environment (where there is a finite availability of nitrogen) to the theoretical growth rate if there were no such limit on nitrogen availability.", "dimensions": "longitude latitude time", "out_name": "limnpico", "type": "real", @@ -2704,7 +2704,7 @@ "cell_methods": "time: mean", "cell_measures": "", "long_name": "Sea Water Transport", - "comment": "", + "comment": "Transport across_line means that which crosses a particular line on the Earth's surface; formally this means the integral along the line of the normal component of the transport.", "dimensions": "oline time", "out_name": "mfo", "type": "real", @@ -2776,7 +2776,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Square of Ocean Mixed Layer Thickness Defined by Sigma T", - "comment": "", + "comment": "The ocean mixed layer is the upper part of the ocean, regarded as being well-mixed. The base of the mixed layer defined by temperature, sigma, sigma_theta or sigma_t is the level at which the quantity indicated differs from its surface value by a certain amount. 'Thickness' means the vertical extent of a layer. 'square_of_X' means X*X.", "dimensions": "longitude latitude time", "out_name": "mlotstsq", "type": "real", @@ -2990,10 +2990,10 @@ "standard_name": "mole_concentration_of_ammonium_in_sea_water", "units": "mol m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Dissolved Ammonium Concentration", - "comment": "", - "dimensions": "longitude latitude olevel time", + "comment": "Mole concentration means moles (amount of substance) per unit volume and is used in the construction mole_concentration_of_X_in_Y, where X is a material constituent of Y.", + "dimensions": "longitude latitude time depth0m", "out_name": "nh4", "type": "real", "positive": "", @@ -3008,10 +3008,10 @@ "standard_name": "mole_concentration_of_nitrate_in_sea_water", "units": "mol m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Dissolved Nitrate Concentration", - "comment": "", - "dimensions": "longitude latitude olevel time", + "comment": "Mole concentration means moles (amount of substance) per unit volume and is used in the construction mole_concentration_of_X_in_Y, where X is a material constituent of Y.", + "dimensions": "longitude latitude time depth0m", "out_name": "no3", "type": "real", "positive": "", @@ -3028,8 +3028,8 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Surface Dissolved Nitrate Concentration", - "comment": "", - "dimensions": "longitude latitude time depth0m", + "comment": "Mole concentration means moles (amount of substance) per unit volume and is used in the construction mole_concentration_of_X_in_Y, where X is a material constituent of Y.", + "dimensions": "longitude latitude time", "out_name": "no3os", "type": "real", "positive": "", @@ -3044,10 +3044,10 @@ "standard_name": "mole_concentration_of_dissolved_molecular_oxygen_in_sea_water", "units": "mol m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Dissolved Oxygen Concentration", - "comment": "", - "dimensions": "longitude latitude olevel time", + "comment": "'Mole concentration' means number of moles per unit volume, also called'molarity', and is used in the construction mole_concentration_of_X_in_Y, whereX is a material constituent of Y. A chemical or biological species denoted by X may be described by a single term such as 'nitrogen' or a phrase such as 'nox_expressed_as_nitrogen'.", + "dimensions": "longitude latitude time depth0m", "out_name": "o2", "type": "real", "positive": "", @@ -3064,7 +3064,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Oxygen Minimum Concentration", - "comment": "", + "comment": "'Mole concentration' means number of moles per unit volume, also called 'molarity', and is used in the construction mole_concentration_of_X_in_Y, where X is a material constituent of Y. A chemical or biological species denoted by X may be described by a single term such as 'nitrogen' or a phrase such as 'nox_expressed_as_nitrogen'. The concentration of any chemical species, whether particulate or dissolved, may vary with depth in the ocean. A depth profile may go through one or more local minima in concentration. The mole_concentration_of_molecular_oxygen_in_sea_water_at_shallowest_local_minimum_in_vertical_profile is the mole concentration of oxygen at the local minimum in the concentration profile that occurs closest to the sea surface.", "dimensions": "longitude latitude time", "out_name": "o2min", "type": "real", @@ -3082,8 +3082,8 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Surface Dissolved Oxygen Concentration", - "comment": "", - "dimensions": "longitude latitude time depth0m", + "comment": "'Mole concentration' means number of moles per unit volume, also called'molarity', and is used in the construction mole_concentration_of_X_in_Y, whereX is a material constituent of Y. A chemical or biological species denoted by X may be described by a single term such as 'nitrogen' or a phrase such as 'nox_expressed_as_nitrogen'.", + "dimensions": "longitude latitude time", "out_name": "o2os", "type": "real", "positive": "", @@ -3098,10 +3098,10 @@ "standard_name": "mole_concentration_of_dissolved_molecular_oxygen_in_sea_water_at_saturation", "units": "mol m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Dissolved Oxygen Concentration at Saturation", - "comment": "", - "dimensions": "longitude latitude olevel time", + "comment": "'Mole concentration at saturation' means the mole concentration in a saturated solution. Mole concentration means number of moles per unit volume, also called 'molarity', and is used in the construction 'mole_concentration_of_X_in_Y', where X is a material constituent of Y. A chemical or biological species denoted by X may be described by a single term such as 'nitrogen' or a phrase such as 'nox_expressed_as_nitrogen'.", + "dimensions": "longitude latitude time depth0m", "out_name": "o2sat", "type": "real", "positive": "", @@ -3118,8 +3118,8 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Surface Dissolved Oxygen Concentration at Saturation", - "comment": "", - "dimensions": "longitude latitude time depth0m", + "comment": "'Mole concentration at saturation' means the mole concentration in a saturated solution. Mole concentration means number of moles per unit volume, also called 'molarity', and is used in the construction 'mole_concentration_of_X_in_Y', where X is a material constituent of Y. A chemical or biological species denoted by X may be described by a single term such as 'nitrogen' or a phrase such as 'nox_expressed_as_nitrogen'.", + "dimensions": "longitude latitude time", "out_name": "o2satos", "type": "real", "positive": "", @@ -3136,7 +3136,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello volume: volcello", "long_name": "Square of Brunt Vaisala Frequency in Sea Water", - "comment": "", + "comment": "The phrase 'square_of_X' means X*X. Frequency is the number of oscillations of a wave per unit time. Brunt-Vaisala frequency is also sometimes called 'buoyancy frequency' and is a measure of the vertical stratification of the medium.", "dimensions": "longitude latitude olevel time", "out_name": "obvfsq", "type": "real", @@ -3164,24 +3164,6 @@ "ok_min_mean_abs": "", "ok_max_mean_abs": "" }, - "pbfe": { - "frequency": "mon", - "modeling_realm": "ocnBgChem", - "standard_name": "tendency_of_mole_concentration_of_iron_in_sea_water_due_to_biological_production", - "units": "mol m-3 s-1", - "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello", - "long_name": "Biogenic Iron Production", - "comment": "", - "dimensions": "longitude latitude time depth0m", - "out_name": "pbfe", - "type": "real", - "positive": "", - "valid_min": "", - "valid_max": "", - "ok_min_mean_abs": "", - "ok_max_mean_abs": "" - }, "pbo": { "frequency": "mon", "modeling_realm": "ocean", @@ -3190,7 +3172,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Sea Water Pressure at Sea floor", - "comment": "", + "comment": "'Sea water pressure' is the pressure that exists in the medium of sea water. It includes the pressure due to overlying sea water, sea ice, air and any other medium that may be present.", "dimensions": "longitude latitude time", "out_name": "pbo", "type": "real", @@ -3200,34 +3182,16 @@ "ok_min_mean_abs": "", "ok_max_mean_abs": "" }, - "pbsi": { - "frequency": "mon", - "modeling_realm": "ocnBgChem", - "standard_name": "tendency_of_mole_concentration_of_silicon_in_sea_water_due_to_biological_production", - "units": "mol m-3 s-1", - "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello", - "long_name": "Biogenic Silica Production", - "comment": "", - "dimensions": "longitude latitude time depth0m", - "out_name": "pbsi", - "type": "real", - "positive": "", - "valid_min": "", - "valid_max": "", - "ok_min_mean_abs": "", - "ok_max_mean_abs": "" - }, "ph": { "frequency": "mon", "modeling_realm": "ocnBgChem", "standard_name": "sea_water_ph_reported_on_total_scale", "units": "1", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "pH", "comment": "negative log of hydrogen ion concentration with the concentration expressed as mol H kg-1.", - "dimensions": "longitude latitude olevel time", + "dimensions": "longitude latitude time depth0m", "out_name": "ph", "type": "real", "positive": "", @@ -3242,10 +3206,10 @@ "standard_name": "sea_water_ph_abiotic_analogue_reported_on_total_scale", "units": "1", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Abiotic pH", "comment": "negative log10 of hydrogen ion concentration with the concentration expressed as mol H kg-1 (abiotic component)..", - "dimensions": "longitude latitude olevel time", + "dimensions": "longitude latitude time depth0m", "out_name": "phabio", "type": "real", "positive": "", @@ -3263,7 +3227,7 @@ "cell_measures": "area: areacello", "long_name": "Surface Abiotic pH", "comment": "negative log10 of hydrogen ion concentration with the concentration expressed as mol H kg-1.", - "dimensions": "longitude latitude time depth0m", + "dimensions": "longitude latitude time", "out_name": "phabioos", "type": "real", "positive": "", @@ -3278,10 +3242,10 @@ "standard_name": "sea_water_ph_natural_analogue_reported_on_total_scale", "units": "1", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Natural pH", "comment": "negative log10 of hydrogen ion concentration with the concentration expressed as mol H kg-1.", - "dimensions": "longitude latitude olevel time", + "dimensions": "longitude latitude time depth0m", "out_name": "phnat", "type": "real", "positive": "", @@ -3299,7 +3263,7 @@ "cell_measures": "area: areacello", "long_name": "Surface Natural pH", "comment": "negative log10 of hydrogen ion concentration with the concentration expressed as mol H kg-1.", - "dimensions": "longitude latitude time depth0m", + "dimensions": "longitude latitude time", "out_name": "phnatos", "type": "real", "positive": "", @@ -3314,10 +3278,10 @@ "standard_name": "mole_concentration_of_phytoplankton_expressed_as_carbon_in_sea_water", "units": "mol m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Phytoplankton Carbon Concentration", "comment": "sum of phytoplankton carbon component concentrations. In most (all?) cases this is the sum of phycdiat and phycmisc (i.e., 'Diatom Carbon Concentration' and 'Non-Diatom Phytoplankton Carbon Concentration'", - "dimensions": "longitude latitude olevel time", + "dimensions": "longitude latitude time depth0m", "out_name": "phyc", "type": "real", "positive": "", @@ -3332,10 +3296,10 @@ "standard_name": "mole_concentration_of_calcareous_phytoplankton_expressed_as_carbon_in_sea_water", "units": "mol m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Mole Concentration of Calcareous Phytoplankton expressed as Carbon in sea water", "comment": "carbon concentration from calcareous (calcite-producing) phytoplankton component alone", - "dimensions": "longitude latitude olevel time", + "dimensions": "longitude latitude time depth0m", "out_name": "phycalc", "type": "real", "positive": "", @@ -3353,7 +3317,7 @@ "cell_measures": "area: areacello", "long_name": "Surface Phytoplankton Carbon Concentration", "comment": "sum of phytoplankton organic carbon component concentrations at the sea surface", - "dimensions": "longitude latitude time depth0m", + "dimensions": "longitude latitude time", "out_name": "phycos", "type": "real", "positive": "", @@ -3368,10 +3332,10 @@ "standard_name": "mole_concentration_of_diatoms_expressed_as_carbon_in_sea_water", "units": "mol m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Mole Concentration of Diatoms expressed as Carbon in sea water", "comment": "carbon from the diatom phytoplankton component concentration alone", - "dimensions": "longitude latitude olevel time", + "dimensions": "longitude latitude time depth0m", "out_name": "phydiat", "type": "real", "positive": "", @@ -3386,10 +3350,10 @@ "standard_name": "mole_concentration_of_diazotrophs_expressed_as_carbon_in_sea_water", "units": "mol m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Mole Concentration of Diazotrophs Expressed as Carbon in sea water", "comment": "carbon concentration from the diazotrophic phytoplankton component alone", - "dimensions": "longitude latitude olevel time", + "dimensions": "longitude latitude time depth0m", "out_name": "phydiaz", "type": "real", "positive": "", @@ -3404,10 +3368,10 @@ "standard_name": "mole_concentration_of_phytoplankton_expressed_as_iron_in_sea_water", "units": "mol m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Mole Concentration of Total Phytoplankton expressed as Iron in sea water", "comment": "sum of phytoplankton iron component concentrations", - "dimensions": "longitude latitude olevel time", + "dimensions": "longitude latitude time depth0m", "out_name": "phyfe", "type": "real", "positive": "", @@ -3425,7 +3389,7 @@ "cell_measures": "area: areacello", "long_name": "Surface Mole Concentration of Total Phytoplankton expressed as Iron in Sea Water", "comment": "sum of phytoplankton iron component concentrations", - "dimensions": "longitude latitude time depth0m", + "dimensions": "longitude latitude time", "out_name": "phyfeos", "type": "real", "positive": "", @@ -3440,10 +3404,10 @@ "standard_name": "mole_concentration_of_miscellaneous_phytoplankton_expressed_as_carbon_in_sea_water", "units": "mol m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Mole Concentration of Miscellaneous Phytoplankton expressed as Carbon in sea water", "comment": "carbon concentration from additional phytoplankton component alone", - "dimensions": "longitude latitude olevel time", + "dimensions": "longitude latitude time depth0m", "out_name": "phymisc", "type": "real", "positive": "", @@ -3458,10 +3422,10 @@ "standard_name": "mole_concentration_of_phytoplankton_expressed_as_nitrogen_in_sea_water", "units": "mol m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Mole Concentration of Total Phytoplankton expressed as Nitrogen in sea water", "comment": "sum of phytoplankton nitrogen component concentrations", - "dimensions": "longitude latitude olevel time", + "dimensions": "longitude latitude time depth0m", "out_name": "phyn", "type": "real", "positive": "", @@ -3479,7 +3443,7 @@ "cell_measures": "area: areacello", "long_name": "Surface Mole Concentration of Phytoplankton Nitrogen in sea water", "comment": "sum of phytoplankton nitrogen component concentrations", - "dimensions": "longitude latitude time depth0m", + "dimensions": "longitude latitude time", "out_name": "phynos", "type": "real", "positive": "", @@ -3494,10 +3458,10 @@ "standard_name": "mole_concentration_of_phytoplankton_expressed_as_phosphorus_in_sea_water", "units": "mol m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Mole Concentration of Total Phytoplankton expressed as Phosphorus in sea water", "comment": "sum of phytoplankton phosphorus components", - "dimensions": "longitude latitude olevel time", + "dimensions": "longitude latitude time depth0m", "out_name": "phyp", "type": "real", "positive": "", @@ -3512,10 +3476,10 @@ "standard_name": "mole_concentration_of_picophytoplankton_expressed_as_carbon_in_sea_water", "units": "mol m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Mole Concentration of Picophytoplankton expressed as Carbon in sea water", "comment": "carbon concentration from the picophytoplankton (<2 um) component alone", - "dimensions": "longitude latitude olevel time", + "dimensions": "longitude latitude time depth0m", "out_name": "phypico", "type": "real", "positive": "", @@ -3533,7 +3497,7 @@ "cell_measures": "area: areacello", "long_name": "Surface Mole Concentration of Total Phytoplankton expressed as Phosphorus in sea water", "comment": "sum of phytoplankton phosphorus components", - "dimensions": "longitude latitude time depth0m", + "dimensions": "longitude latitude time", "out_name": "phypos", "type": "real", "positive": "", @@ -3548,10 +3512,10 @@ "standard_name": "mole_concentration_of_phytoplankton_expressed_as_silicon_in_sea_water", "units": "mol m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Mole Concentration of Total Phytoplankton expressed as Silicon in sea water", "comment": "sum of phytoplankton silica component concentrations", - "dimensions": "longitude latitude olevel time", + "dimensions": "longitude latitude time depth0m", "out_name": "physi", "type": "real", "positive": "", @@ -3569,7 +3533,7 @@ "cell_measures": "area: areacello", "long_name": "Surface Mole Concentration of Total Phytoplankton expressed as Silicon in sea water", "comment": "sum of phytoplankton silica component concentrations", - "dimensions": "longitude latitude time depth0m", + "dimensions": "longitude latitude time", "out_name": "physios", "type": "real", "positive": "", @@ -3578,34 +3542,16 @@ "ok_min_mean_abs": "", "ok_max_mean_abs": "" }, - "pnitrate": { - "frequency": "mon", - "modeling_realm": "ocnBgChem", - "standard_name": "tendency_of_mole_concentration_of_particulate_organic_matter_expressed_as_carbon_in_sea_water_due_to_nitrate_utilization", - "units": "mol m-3 s-1", - "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello", - "long_name": "Primary Carbon Production by Phytoplankton due to Nitrate Uptake Alone", - "comment": "Primary (organic carbon) production by phytoplankton due to nitrate uptake alone", - "dimensions": "longitude latitude time depth0m", - "out_name": "pnitrate", - "type": "real", - "positive": "", - "valid_min": "", - "valid_max": "", - "ok_min_mean_abs": "", - "ok_max_mean_abs": "" - }, "po4": { "frequency": "mon", "modeling_realm": "ocnBgChem", "standard_name": "mole_concentration_of_dissolved_inorganic_phosphorus_in_sea_water", "units": "mol m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Total Dissolved Inorganic Phosphorus Concentration", - "comment": "", - "dimensions": "longitude latitude olevel time", + "comment": "Mole concentration means number of moles per unit volume, also called 'molarity', and is used in the construction 'mole_concentration_of_X_in_Y', where X is a material constituent of Y. A chemical or biological species denoted by X may be described by a single term such as 'nitrogen' or a phrase such as 'nox_expressed_as_nitrogen'. 'Dissolved inorganic phosphorus' means the sum of all inorganic phosphorus in solution (including phosphate, hydrogen phosphate, dihydrogen phosphate, and phosphoric acid).", + "dimensions": "longitude latitude time depth0m", "out_name": "po4", "type": "real", "positive": "", @@ -3620,10 +3566,10 @@ "standard_name": "mole_concentration_of_particulate_organic_matter_expressed_as_nitrogen_in_sea_water", "units": "mol m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Mole Concentration of Particulate Organic Matter expressed as Nitrogen in sea water", "comment": "sum of particulate organic nitrogen component concentrations", - "dimensions": "longitude latitude olevel time", + "dimensions": "longitude latitude time depth0m", "out_name": "pon", "type": "real", "positive": "", @@ -3641,7 +3587,7 @@ "cell_measures": "area: areacello", "long_name": "Surface Mole Concentration of Particulate Organic Matter expressed as Nitrogen in sea water", "comment": "sum of particulate organic nitrogen component concentrations", - "dimensions": "longitude latitude time depth0m", + "dimensions": "longitude latitude time", "out_name": "ponos", "type": "real", "positive": "", @@ -3656,10 +3602,10 @@ "standard_name": "mole_concentration_of_particulate_organic_matter_expressed_as_phosphorus_in_sea_water", "units": "mol m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Mole Concentration of Particulate Organic Matter expressed as Phosphorus in sea water", "comment": "sum of particulate organic phosphorus component concentrations", - "dimensions": "longitude latitude olevel time", + "dimensions": "longitude latitude time depth0m", "out_name": "pop", "type": "real", "positive": "", @@ -3677,7 +3623,7 @@ "cell_measures": "area: areacello", "long_name": "Surface Mole Concentration of Particulate Organic Matter expressed as Phosphorus in sea water", "comment": "sum of particulate organic phosphorus component concentrations", - "dimensions": "longitude latitude time depth0m", + "dimensions": "longitude latitude time", "out_name": "popos", "type": "real", "positive": "", @@ -3692,10 +3638,10 @@ "standard_name": "tendency_of_mole_concentration_of_particulate_organic_matter_expressed_as_carbon_in_sea_water_due_to_net_primary_production", "units": "mol m-3 s-1", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Primary Carbon Production by Total Phytoplankton", "comment": "total primary (organic carbon) production by phytoplankton", - "dimensions": "longitude latitude olevel time", + "dimensions": "longitude latitude time depth0m", "out_name": "pp", "type": "real", "positive": "", @@ -3712,7 +3658,7 @@ "cell_methods": "area: mean where ice_free_sea over sea time: mean", "cell_measures": "area: areacello", "long_name": "Rainfall Flux where Ice Free Ocean over Sea", - "comment": "", + "comment": "In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "longitude latitude time", "out_name": "prra", "type": "real", @@ -3748,7 +3694,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Sea Water Pressure at Sea Water Surface", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'Sea water pressure' is the pressure that exists in the medium of sea water. It includes the pressure due to overlying sea water, sea ice, air and any other medium that may be present.", "dimensions": "longitude latitude time", "out_name": "pso", "type": "real", @@ -3784,7 +3730,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello volume: volcello", "long_name": "Downwelling Shortwave Radiation in Sea Water", - "comment": "", + "comment": "Downwelling radiation is radiation from above. It does not mean 'net downward'. When thought of as being incident on a surface, a radiative flux is sometimes called 'irradiance'. In addition, it is identical with the quantity measured by a cosine-collector light-meter and sometimes called 'vector irradiance'. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics. 'shortwave' means shortwave radiation.", "dimensions": "longitude latitude olevel time", "out_name": "rsdo", "type": "real", @@ -3820,7 +3766,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello volume: volcello", "long_name": "Moles Per Unit Mass of SF6 in sea water", - "comment": "", + "comment": "Mole concentration means number of moles per unit volume, also called 'molarity', and is used in the construction 'mole_concentration_of_X_in_Y', where X is a material constituent of Y. A chemical or biological species denoted by X may be described by a single term such as 'nitrogen' or a phrase such as 'nox_expressed_as_nitrogen'. The chemical formula of sulfur hexafluoride is SF6.", "dimensions": "longitude latitude olevel time", "out_name": "sf6", "type": "real", @@ -3872,10 +3818,10 @@ "standard_name": "mole_concentration_of_dissolved_inorganic_silicon_in_sea_water", "units": "mol m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Total Dissolved Inorganic Silicon Concentration", - "comment": "", - "dimensions": "longitude latitude olevel time", + "comment": "Mole concentration means number of moles per unit volume, also called 'molarity', and is used in the construction 'mole_concentration_of_X_in_Y', where X is a material constituent of Y. A chemical or biological species denoted by X may be described by a single term such as 'nitrogen' or a phrase such as 'nox_expressed_as_nitrogen'. 'Dissolved inorganic silicon' means the sum of all inorganic silicon in solution (including silicic acid and its first dissociated anion SiO(OH)3-).", + "dimensions": "longitude latitude time depth0m", "out_name": "si", "type": "real", "positive": "", @@ -3892,8 +3838,8 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Surface Total Dissolved Inorganic Silicon Concentration", - "comment": "", - "dimensions": "longitude latitude time depth0m", + "comment": "Mole concentration means number of moles per unit volume, also called 'molarity', and is used in the construction 'mole_concentration_of_X_in_Y', where X is a material constituent of Y. A chemical or biological species denoted by X may be described by a single term such as 'nitrogen' or a phrase such as 'nox_expressed_as_nitrogen'. 'Dissolved inorganic silicon' means the sum of all inorganic silicon in solution (including silicic acid and its first dissociated anion SiO(OH)3-).", + "dimensions": "longitude latitude time", "out_name": "sios", "type": "real", "positive": "", @@ -3946,7 +3892,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello volume: volcello", "long_name": "Sea Water Salinity", - "comment": "", + "comment": "Sea water salinity is the salt content of sea water, often on the Practical Salinity Scale of 1978. However, the unqualified term 'salinity' is generic and does not necessarily imply any particular method of calculation. The units of salinity are dimensionless and the units attribute should normally be given as 1e-3 or 0.001 i.e. parts per thousand. There are standard names for the more precisely defined salinity quantities: sea_water_knudsen_salinity, S_K (used for salinity observations between 1901 and 1966), sea_water_cox_salinity, S_C (used for salinity observations between 1967 and 1977), sea_water_practical_salinity, S_P (used for salinity observations from 1978 to the present day), sea_water_absolute_salinity, S_A, sea_water_preformed_salinity, S_*, and sea_water_reference_salinity. Practical Salinity is reported on the Practical Salinity Scale of 1978 (PSS-78), and is usually based on the electrical conductivity of sea water in observations since the 1960s.", "dimensions": "longitude latitude olevel time", "out_name": "so", "type": "real", @@ -3982,7 +3928,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "", "long_name": "Global Mean Sea Water Salinity", - "comment": "", + "comment": "Sea water salinity is the salt content of sea water, often on the Practical Salinity Scale of 1978. However, the unqualified term 'salinity' is generic and does not necessarily imply any particular method of calculation. The units of salinity are dimensionless and the units attribute should normally be given as 1e-3 or 0.001 i.e. parts per thousand. There are standard names for the more precisely defined salinity quantities: sea_water_knudsen_salinity, S_K (used for salinity observations between 1901 and 1966), sea_water_cox_salinity, S_C (used for salinity observations between 1967 and 1977), sea_water_practical_salinity, S_P (used for salinity observations from 1978 to the present day), sea_water_absolute_salinity, S_A, sea_water_preformed_salinity, S_*, and sea_water_reference_salinity. Practical Salinity is reported on the Practical Salinity Scale of 1978 (PSS-78), and is usually based on the electrical conductivity of sea water in observations since the 1960s.", "dimensions": "time", "out_name": "soga", "type": "real", @@ -4000,7 +3946,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Sea Surface Salinity", - "comment": "", + "comment": "Sea surface salinity is the salt content of sea water close to the sea surface, often on the Practical Salinity Scale of 1978. However, the unqualified term 'salinity' is generic and does not necessarily imply any particular method of calculation. The units of salinity are dimensionless and the units attribute should normally be given as 1e-3 or 0.001 i.e. parts per thousand. Sea surface salinity is often abbreviated as 'SSS'. For the salinity of sea water at a particular depth or layer, a data variable of 'sea_water_salinity' or one of the more precisely defined salinities should be used with a vertical coordinate axis.", "dimensions": "longitude latitude time", "out_name": "sos", "type": "real", @@ -4018,7 +3964,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "", "long_name": "Global Average Sea Surface Salinity", - "comment": "", + "comment": "Sea surface salinity is the salt content of sea water close to the sea surface, often on the Practical Salinity Scale of 1978. However, the unqualified term 'salinity' is generic and does not necessarily imply any particular method of calculation. The units of salinity are dimensionless and the units attribute should normally be given as 1e-3 or 0.001 i.e. parts per thousand. Sea surface salinity is often abbreviated as 'SSS'. For the salinity of sea water at a particular depth or layer, a data variable of 'sea_water_salinity' or one of the more precisely defined salinities should be used with a vertical coordinate axis.", "dimensions": "time", "out_name": "sosga", "type": "real", @@ -4054,7 +4000,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Surface Aqueous Partial Pressure of CO2", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. The partial pressure of a dissolved gas in sea water is the partial pressure in air with which it would be in equilibrium. The partial pressure of a gaseous constituent of air is the pressure which it alone would exert with unchanged temperature and number of moles per unit volume. The chemical formula for carbon dioxide is CO2.", "dimensions": "longitude latitude time depth0m", "out_name": "spco2", "type": "real", @@ -4067,12 +4013,12 @@ "spco2abio": { "frequency": "mon", "modeling_realm": "ocnBgChem", - "standard_name": "surface_partial_pressure_of_carbon_dioxide_abiotic_analogue_in_sea_water", + "standard_name": "surface_carbon_dioxide_abiotic_analogue_partial_pressure_difference_between_sea_water_and_air", "units": "Pa", "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Abiotic Surface Aqueous Partial Pressure of CO2", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. The chemical formula for carbon dioxide is CO2. In ocean biogeochemistry models, an 'abiotic analogue' is used to simulate the effect on a modelled variable when biological effects on ocean carbon concentration and alkalinity are ignored. The partial pressure of a gaseous constituent of air is the pressure which it alone would exert with unchanged temperature and number of moles per unit volume. The partial pressure of a dissolved gas in sea water is the partial pressure in air with which it would be in equilibrium. The partial pressure difference between sea water and air is positive when the partial pressure of the dissolved gas in sea water is greater than the partial pressure in air.", "dimensions": "longitude latitude time depth0m", "out_name": "spco2abio", "type": "real", @@ -4085,12 +4031,12 @@ "spco2nat": { "frequency": "mon", "modeling_realm": "ocnBgChem", - "standard_name": "surface_partial_pressure_of_carbon_dioxide_natural_analogue_in_sea_water", + "standard_name": "surface_carbon_dioxide_natural_analogue_partial_pressure_difference_between_sea_water_and_air", "units": "Pa", "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Natural Surface Aqueous Partial Pressure of CO2", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. The chemical formula for carbon dioxide is CO2. In ocean biogeochemistry models, a 'natural analogue' is used to simulate the effect on a modelled variable of imposing preindustrial atmospheric carbon dioxide concentrations, even when the model as a whole may be subjected to varying forcings. The partial pressure of a gaseous constituent of air is the pressure which it alone would exert with unchanged temperature and number of moles per unit volume. The partial pressure of a dissolved gas in sea water is the partial pressure in air with which it would be in equilibrium. The partial pressure difference between sea water and air is positive when the partial pressure of the dissolved gas in sea water is greater than the partial pressure in air.", "dimensions": "longitude latitude time depth0m", "out_name": "spco2nat", "type": "real", @@ -4106,10 +4052,10 @@ "standard_name": "sea_water_alkalinity_expressed_as_mole_equivalent", "units": "mol m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Total Alkalinity", "comment": "total alkalinity equivalent concentration (including carbonate, nitrogen, silicate, and borate components)", - "dimensions": "longitude latitude olevel time", + "dimensions": "longitude latitude time depth0m", "out_name": "talk", "type": "real", "positive": "", @@ -4124,10 +4070,10 @@ "standard_name": "sea_water_alkalinity_natural_analogue_expressed_as_mole_equivalent", "units": "mol m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Natural Total Alkalinity", "comment": "total alkalinity equivalent concentration (including carbonate, borate, phosphorus, silicon, and nitrogen components) at preindustrial atmospheric xCO2", - "dimensions": "longitude latitude olevel time", + "dimensions": "longitude latitude time depth0m", "out_name": "talknat", "type": "real", "positive": "", @@ -4145,7 +4091,7 @@ "cell_measures": "area: areacello", "long_name": "Surface Natural Total Alkalinity", "comment": "total alkalinity equivalent concentration (including carbonate, borate, phosphorus, silicon, and nitrogen components) at preindustrial atmospheric xCO2", - "dimensions": "longitude latitude time depth0m", + "dimensions": "longitude latitude time", "out_name": "talknatos", "type": "real", "positive": "", @@ -4270,7 +4216,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello volume: volcello", "long_name": "Ocean Model Cell Thickness", - "comment": "", + "comment": "'Thickness' means the vertical extent of a layer. 'Cell' refers to a model grid-cell.", "dimensions": "longitude latitude olevel time", "out_name": "thkcello", "type": "real", @@ -4425,7 +4371,7 @@ "ok_max_mean_abs": "" }, "volcello": { - "frequency": "fx", + "frequency": "mon", "modeling_realm": "ocean", "standard_name": "ocean_volume", "units": "m3", @@ -4648,7 +4594,7 @@ "cell_methods": "time: mean", "cell_measures": "--OPT", "long_name": "Sea Water Z Velocity", - "comment": "", + "comment": "A velocity is a vector quantity. 'Upward' indicates a vector component which is positive when directed upward (negative downward).", "dimensions": "longitude latitude olevel time", "out_name": "wo", "type": "real", @@ -4700,10 +4646,10 @@ "standard_name": "mole_concentration_of_mesozooplankton_expressed_as_carbon_in_sea_water", "units": "mol m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Mole Concentration of Mesozooplankton expressed as Carbon in sea water", "comment": "carbon concentration from mesozooplankton (20-200 um) component alone", - "dimensions": "longitude latitude olevel time", + "dimensions": "longitude latitude time depth0m", "out_name": "zmeso", "type": "real", "positive": "", @@ -4718,10 +4664,10 @@ "standard_name": "mole_concentration_of_microzooplankton_expressed_as_carbon_in_sea_water", "units": "mol m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Mole Concentration of Microzooplankton expressed as Carbon in sea water", "comment": "carbon concentration from the microzooplankton (<20 um) component alone", - "dimensions": "longitude latitude olevel time", + "dimensions": "longitude latitude time depth0m", "out_name": "zmicro", "type": "real", "positive": "", @@ -4736,10 +4682,10 @@ "standard_name": "mole_concentration_of_miscellaneous_zooplankton_expressed_as_carbon_in_sea_water", "units": "mol m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Mole Concetration of Other Zooplankton expressed as Carbon in sea water", "comment": "carbon from additional zooplankton component concentrations alone (e.g. Micro, meso). Since the models all have different numbers of components, this variable has been included to provide a check for intercomparison between models since some phytoplankton groups are supersets.", - "dimensions": "longitude latitude olevel time", + "dimensions": "longitude latitude time depth0m", "out_name": "zmisc", "type": "real", "positive": "", @@ -4772,10 +4718,10 @@ "standard_name": "mole_concentration_of_zooplankton_expressed_as_carbon_in_sea_water", "units": "mol m-3", "cell_methods": "area: mean where sea time: mean", - "cell_measures": "area: areacello volume: volcello", + "cell_measures": "area: areacello", "long_name": "Zooplankton Carbon Concentration", "comment": "sum of zooplankton carbon component concentrations", - "dimensions": "longitude latitude olevel time", + "dimensions": "longitude latitude time depth0m", "out_name": "zooc", "type": "real", "positive": "", diff --git a/TestTables/CMIP6_Oyr.json b/TestTables/CMIP6_Oyr.json index 038ef686..3744ca48 100644 --- a/TestTables/CMIP6_Oyr.json +++ b/TestTables/CMIP6_Oyr.json @@ -1,10 +1,10 @@ { "Header": { - "data_specs_version": "01.00.21", + "data_specs_version": "01.00.23", + "cmor_version": "3.3", "table_id": "Table Oyr", "realm": "ocnBgChem", - "cmor_version": "3.2", - "table_date": "14 February 2018", + "table_date": "21 March 2018", "missing_value": "1e20", "int_missing_value": "-999", "product": "model-output", @@ -166,7 +166,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello volume: volcello", "long_name": "Mole Concentration of CFC-11 in sea water", - "comment": "", + "comment": "Mole concentration means number of moles per unit volume, also called 'molarity', and is used in the construction 'mole_concentration_of_X_in_Y', where X is a material constituent of Y. A chemical or biological species denoted by X may be described by a single term such as 'nitrogen' or a phrase such as 'nox_expressed_as_nitrogen'. The chemical formula of CFC11 is CFCl3. The IUPAC name fof CFC11 is trichloro-fluoro-methane.", "dimensions": "longitude latitude olevel time", "out_name": "cfc11", "type": "real", @@ -184,7 +184,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello volume: volcello", "long_name": "Mole Concentration of CFC-12 in sea water", - "comment": "", + "comment": "Mole concentration means number of moles per unit volume, also called 'molarity', and is used in the construction 'mole_concentration_of_X_in_Y', where X is a material constituent of Y. A chemical or biological species denoted by X may be described by a single term such as 'nitrogen' or a phrase such as 'nox_expressed_as_nitrogen'. The chemical formula for CFC12 is CF2Cl2. The IUPAC name for CFC12 is dichloro-difluoro-methane.", "dimensions": "longitude latitude olevel time", "out_name": "cfc12", "type": "real", @@ -634,7 +634,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello volume: volcello", "long_name": "Sinking Particulate Iron Flux", - "comment": "", + "comment": "In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics. 'Sinking' is the gravitational settling of particulate matter suspended in a liquid. A sinking flux is positive downwards and is calculated relative to the movement of the surrounding fluid.", "dimensions": "longitude latitude olevel time", "out_name": "expfe", "type": "real", @@ -652,7 +652,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello volume: volcello", "long_name": "Sinking Particulate Organic Nitrogen Flux", - "comment": "", + "comment": "In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics. 'Sinking' is the gravitational settling of particulate matter suspended in a liquid. A sinking flux is positive downwards and is calculated relative to the movement of the surrounding fluid.", "dimensions": "longitude latitude olevel time", "out_name": "expn", "type": "real", @@ -670,7 +670,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello volume: volcello", "long_name": "Sinking Particulate Organic Phosphorus Flux", - "comment": "", + "comment": "In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics. 'Sinking' is the gravitational settling of particulate matter suspended in a liquid. A sinking flux is positive downwards and is calculated relative to the movement of the surrounding fluid.", "dimensions": "longitude latitude olevel time", "out_name": "expp", "type": "real", @@ -688,7 +688,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello volume: volcello", "long_name": "Sinking Particulate Silica Flux", - "comment": "", + "comment": "In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics. 'Sinking' is the gravitational settling of particulate matter suspended in a liquid. A sinking flux is positive downwards and is calculated relative to the movement of the surrounding fluid.", "dimensions": "longitude latitude olevel time", "out_name": "expsi", "type": "real", @@ -742,7 +742,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "Surface Downward Flux of Abiotic 13CO2", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'Downward' indicates a vector component which is positive when directed downward (negative upward). In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics. In ocean biogeochemistry models, an 'abiotic analogue' is used to simulate the effect on a modelled variable when biological effects on ocean carbon concentration and alkalinity are ignored. The phrase 'expressed_as' is used in the construction A_expressed_as_B, where B is a chemical constituent of A. It means that the quantity indicated by the standard name is calculated solely with respect to the B contained in A, neglecting all other chemical constituents of A. Carbon13 is a stable isotope of carbon having six protons and seven neutrons.", "dimensions": "longitude latitude time", "out_name": "fg13co2", "type": "real", @@ -832,7 +832,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello volume: volcello", "long_name": "Total Grazing of Phytoplankton by Zooplankton", - "comment": "", + "comment": "'tendency_of_X' means derivative of X with respect to time. Mole concentration means number of moles per unit volume, also called 'molarity', and is used in the construction 'mole_concentration_of_X_in_Y', where X is a material constituent of Y. A chemical or biological species denoted by X may be described by a single term such as 'nitrogen' or a phrase such as 'nox_expressed_as_nitrogen'. The phrase 'expressed_as' is used in the construction A_expressed_as_B, where B is a chemical constituent of A. It means that the quantity indicated by the standard name is calculated solely with respect to the B contained in A, neglecting all other chemical constituents of A. The specification of a physical process by the phrase 'due_to_' process means that the quantity named is a single term in a sum of terms which together compose the general quantity named by omitting the phrase.", "dimensions": "longitude latitude olevel time", "out_name": "graz", "type": "real", @@ -850,7 +850,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello volume: volcello", "long_name": "Dissolved Nitrate Concentration", - "comment": "", + "comment": "Mole concentration means moles (amount of substance) per unit volume and is used in the construction mole_concentration_of_X_in_Y, where X is a material constituent of Y.", "dimensions": "longitude latitude olevel time", "out_name": "no3", "type": "real", @@ -868,7 +868,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello volume: volcello", "long_name": "Dissolved Oxygen Concentration", - "comment": "", + "comment": "'Mole concentration' means number of moles per unit volume, also called'molarity', and is used in the construction mole_concentration_of_X_in_Y, whereX is a material constituent of Y. A chemical or biological species denoted by X may be described by a single term such as 'nitrogen' or a phrase such as 'nox_expressed_as_nitrogen'.", "dimensions": "longitude latitude olevel time", "out_name": "o2", "type": "real", @@ -886,7 +886,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello volume: volcello", "long_name": "Dissolved Oxygen Concentration at Saturation", - "comment": "", + "comment": "'Mole concentration at saturation' means the mole concentration in a saturated solution. Mole concentration means number of moles per unit volume, also called 'molarity', and is used in the construction 'mole_concentration_of_X_in_Y', where X is a material constituent of Y. A chemical or biological species denoted by X may be described by a single term such as 'nitrogen' or a phrase such as 'nox_expressed_as_nitrogen'.", "dimensions": "longitude latitude olevel time", "out_name": "o2sat", "type": "real", @@ -994,7 +994,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello volume: volcello", "long_name": "tendency of sea water conservative temperature expressed as heat content due to residual mean (sum of Eulerian + parameterized) advection", - "comment": "", + "comment": "'tendency_of_X' means derivative of X with respect to time. 'Content' indicates a quantity per unit area. The phrase 'expressed_as_heat_content' means that this quantity is calculated as the specific heat capacity times density of sea water multiplied by the conservative temperature of the sea water in the grid cell. Conservative Temperature is defined as part of the Thermodynamic Equation of Seawater 2010 (TEOS-10) which was adopted in 2010 by the International Oceanographic Commission (IOC). Conservative Temperature is specific potential enthalpy (which has the standard name sea_water_specific_potential_enthalpy) divided by a fixed value of the specific heat capacity of sea water, namely cp_0 = 3991.86795711963 J kg-1 K-1. Conservative Temperature is a more accurate measure of the 'heat content' of sea water, by a factor of one hundred, than is potential temperature. Because of this, it can be regarded as being proportional to the heat content of sea water per unit mass. Reference: www.teos-10.", "dimensions": "longitude latitude olevel time", "out_name": "ocontemprmadvect", "type": "real", @@ -1048,7 +1048,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello", "long_name": "integral wrt depth of product of sea water density and potential temperature", - "comment": "", + "comment": "The phrase 'integral_wrt_X_of_Y' means int Y dX. The data variable should have an axis for X specifying the limits of the integral as bounds. The phrase 'wrt' means 'with respect to'. The phrase 'product_of_X_and_Y' means X*Y. Depth is the vertical distance below the surface. Sea water density is the in-situ density (not the potential density). For Boussinesq models, density is the constant Boussinesq reference density, a quantity which has the standard name reference_sea_water_density_for_boussinesq_approximation. Potential temperature is the temperature a parcel of air or sea water would have if moved adiabatically to sea level pressure.", "dimensions": "longitude latitude time", "out_name": "opottempmint", "type": "real", @@ -1120,7 +1120,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello volume: volcello", "long_name": "tendency of sea water potential temperature expressed as heat content due to residual mean advection", - "comment": "", + "comment": "The phrase 'tendency_of_X' means derivative of X with respect to time. 'Content' indicates a quantity per unit area. The phrase 'expressed_as_heat_content' means that this quantity is calculated as the specific heat capacity times density of sea water multiplied by the potential temperature of the sea water in the grid cell. Potential temperature is the temperature a parcel of air or sea water would have if moved adiabatically to sea level pressure. The specification of a physical process by the phrase due_to_process means that the quantity named is a single term in a sum of terms which together compose the general quantity named by omitting the phrase. The phrase 'residual_mean_advection' refers to the sum of the model's resolved advective transport plus any parameterized advective transport. Parameterized advective transport includes processes such as parameterized mesoscale and submesoscale transport, as well as any other advectively parameterized transport.", "dimensions": "longitude latitude olevel time", "out_name": "opottemprmadvect", "type": "real", @@ -1228,7 +1228,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello volume: volcello", "long_name": "tendency of sea water salinity expressed as salt content due to residual mean advection", - "comment": "", + "comment": "The phrase 'tendency_of_X' means derivative of X with respect to time. 'Content' indicates a quantity per unit area. The specification of a physical process by the phrase due_to_process means that the quantity named is a single term in a sum of terms which together compose the general quantity named by omitting the phrase. The phrase 'residual_mean_advection' refers to the sum of the model's resolved advective transport plus any parameterized advective transport. Parameterized advective transport includes processes such as parameterized mesoscale and submesoscale transport, as well as any other advectively parameterized transport. When the parameterized advective transport is represented in the model as a skew-diffusion rather than an advection, then the parameterized skew diffusion should be included in this diagnostic, since the convergence of skew-fluxes are identical (in the continuous formulation) to the convergence of advective fluxes.", "dimensions": "longitude latitude olevel time", "out_name": "osaltrmadvect", "type": "real", @@ -1264,7 +1264,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello volume: volcello", "long_name": "Aragonite Production", - "comment": "", + "comment": "'Mole concentration' means number of moles per unit volume, also called'molarity', and is used in the construction mole_concentration_of_X_in_Y, whereX is a material constituent of Y. A chemical or biological species denoted by X may be described by a single term such as 'nitrogen' or a phrase such as 'nox_expressed_as_nitrogen'. The phrase 'expressed_as' is used in the construction A_expressed_as_B, where B is a chemical constituent of A. It means that the quantity indicated by the standard name is calculated solely with respect to the B contained in A, neglecting all other chemical constituents of A. The specification of a physical process by the phrase due_to_process means that the quantity named is a single term in a sum of terms which together compose the general quantity named by omitting the phrase. 'tendency_of_X' means derivative of X with respect to time. Aragonite is a mineral that is a polymorph of calcium carbonate. The chemical formula of aragonite is CaCO3.", "dimensions": "longitude latitude olevel time", "out_name": "parag", "type": "real", @@ -1282,7 +1282,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello volume: volcello", "long_name": "Biogenic Iron Production", - "comment": "", + "comment": "'Mole concentration' means number of moles per unit volume, also called'molarity', and is used in the construction mole_concentration_of_X_in_Y, whereX is a material constituent of Y. A chemical or biological species denoted by X may be described by a single term such as 'nitrogen' or a phrase such as 'nox_expressed_as_nitrogen'. The specification of a physical process by the phrase due_to_process means that the quantity named is a single term in a sum of terms which together compose the general quantity named by omitting the phrase. 'tendency_of_X' means derivative of X with respect to time.", "dimensions": "longitude latitude olevel time", "out_name": "pbfe", "type": "real", @@ -1300,7 +1300,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello volume: volcello", "long_name": "Biogenic Silica Production", - "comment": "", + "comment": "'Mole concentration' means number of moles per unit volume, also called'molarity', and is used in the construction mole_concentration_of_X_in_Y, whereX is a material constituent of Y. A chemical or biological species denoted by X may be described by a single term such as 'nitrogen' or a phrase such as 'nox_expressed_as_nitrogen'. The specification of a physical process by the phrase due_to_process means that the quantity named is a single term in a sum of terms which together compose the general quantity named by omitting the phrase. 'tendency_of_X' means derivative of X with respect to time.", "dimensions": "longitude latitude olevel time", "out_name": "pbsi", "type": "real", @@ -1318,7 +1318,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello volume: volcello", "long_name": "Calcite Production", - "comment": "", + "comment": "'Mole concentration' means number of moles per unit volume, also called'molarity', and is used in the construction mole_concentration_of_X_in_Y, whereX is a material constituent of Y. A chemical or biological species denoted by X may be described by a single term such as 'nitrogen' or a phrase such as 'nox_expressed_as_nitrogen'. The phrase 'expressed_as' is used in the construction A_expressed_as_B, where B is a chemical constituent of A. It means that the quantity indicated by the standard name is calculated solely with respect to the B contained in A, neglecting all other chemical constituents of A. The specification of a physical process by the phrase due_to_process means that the quantity named is a single term in a sum of terms which together compose the general quantity named by omitting the phrase. 'tendency_of_X' means derivative of X with respect to time. Calcite is a mineral that is a polymorph of calcium carbonate. Thechemical formula of calcite is CaCO3.", "dimensions": "longitude latitude olevel time", "out_name": "pcalc", "type": "real", @@ -1624,7 +1624,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello volume: volcello", "long_name": "Remineralization of Organic Carbon", - "comment": "", + "comment": "'tendency_of_X' means derivative of X with respect to time. Mole concentration means number of moles per unit volume, also called 'molarity', and is used in the construction 'mole_concentration_of_X_in_Y', where X is a material constituent of Y. A chemical or biological species denoted by X may be described by a single term such as 'nitrogen' or a phrase such as 'nox_expressed_as_nitrogen'. The phrase 'expressed_as' is used in the construction A_expressed_as_B, where B is a chemical constituent of A. It means that the quantity indicated by the standard name is calculated solely with respect to the B contained in A, neglecting all other chemical constituents of A. The specification of a physical process by the phrase 'due_to_' process means that the quantity named is a single term in a sum of terms which together compose the general quantity named by omitting the phrase.", "dimensions": "longitude latitude olevel time", "out_name": "remoc", "type": "real", @@ -1642,7 +1642,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello volume: volcello", "long_name": "net rate of absorption of shortwave energy in ocean layer", - "comment": "", + "comment": "'shortwave' means shortwave radiation. 'Layer' means any layer with upper and lower boundaries that have constant values in some vertical coordinate. There must be a vertical coordinate variable indicating the extent of the layer(s). If the layers are model layers, the vertical coordinate can be model_level_number, but it is recommended to specify a physical coordinate (in a scalar or auxiliary coordinate variable) as well. Net absorbed radiation is the difference between absorbed and emitted radiation.", "dimensions": "longitude latitude olevel time", "out_name": "rsdoabsorb", "type": "real", @@ -1660,7 +1660,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello volume: volcello", "long_name": "Mole Concentration of SF6 in sea water", - "comment": "", + "comment": "Mole concentration means number of moles per unit volume, also called 'molarity', and is used in the construction 'mole_concentration_of_X_in_Y', where X is a material constituent of Y. A chemical or biological species denoted by X may be described by a single term such as 'nitrogen' or a phrase such as 'nox_expressed_as_nitrogen'. The chemical formula of sulfur hexafluoride is SF6.", "dimensions": "longitude latitude olevel time", "out_name": "sf6", "type": "real", @@ -1678,7 +1678,7 @@ "cell_methods": "area: mean where sea time: mean", "cell_measures": "area: areacello volume: volcello", "long_name": "Total Dissolved Inorganic Silicon Concentration", - "comment": "", + "comment": "Mole concentration means number of moles per unit volume, also called 'molarity', and is used in the construction 'mole_concentration_of_X_in_Y', where X is a material constituent of Y. A chemical or biological species denoted by X may be described by a single term such as 'nitrogen' or a phrase such as 'nox_expressed_as_nitrogen'. 'Dissolved inorganic silicon' means the sum of all inorganic silicon in solution (including silicic acid and its first dissociated anion SiO(OH)3-).", "dimensions": "longitude latitude olevel time", "out_name": "si", "type": "real", @@ -1761,7 +1761,7 @@ "ok_max_mean_abs": "" }, "volcello": { - "frequency": "fx", + "frequency": "yr", "modeling_realm": "ocean", "standard_name": "ocean_volume", "units": "m3", diff --git a/TestTables/CMIP6_SIday.json b/TestTables/CMIP6_SIday.json index 358924ba..8199ef8f 100644 --- a/TestTables/CMIP6_SIday.json +++ b/TestTables/CMIP6_SIday.json @@ -1,10 +1,10 @@ { "Header": { - "data_specs_version": "01.00.21", + "data_specs_version": "01.00.23", + "cmor_version": "3.3", "table_id": "Table SIday", "realm": "seaIce", - "cmor_version": "3.2", - "table_date": "14 February 2018", + "table_date": "21 March 2018", "missing_value": "1e20", "int_missing_value": "-999", "product": "model-output", diff --git a/TestTables/CMIP6_SImon.json b/TestTables/CMIP6_SImon.json index d224fae1..c07e4249 100644 --- a/TestTables/CMIP6_SImon.json +++ b/TestTables/CMIP6_SImon.json @@ -1,10 +1,10 @@ { "Header": { - "data_specs_version": "01.00.21", + "data_specs_version": "01.00.23", + "cmor_version": "3.3", "table_id": "Table SImon", "realm": "seaIce", - "cmor_version": "3.2", - "table_date": "14 February 2018", + "table_date": "21 March 2018", "missing_value": "1e20", "int_missing_value": "-999", "product": "model-output", @@ -413,7 +413,7 @@ "sidragbot": { "frequency": "mon", "modeling_realm": "seaIce", - "standard_name": "surface_drag_coefficient_for_momentum_in_water", + "standard_name": "surface_drag_coefficient_for_momentum_in_sea_water", "units": "1", "cell_methods": "area: time: mean where sea_ice (comment: mask=siconc or siconca)", "cell_measures": "area: areacello OR areacella", @@ -503,7 +503,7 @@ "siflcondbot": { "frequency": "mon", "modeling_realm": "seaIce", - "standard_name": "conductive_heat_flux_at_sea_ice_bottom", + "standard_name": "sea_ice_basal_net_downward_sensible_heat_flux", "units": "W m-2", "cell_methods": "area: time: mean where sea_ice (comment: mask=siconc or siconca)", "cell_measures": "area: areacello OR areacella", @@ -539,7 +539,7 @@ "siflfwbot": { "frequency": "mon", "modeling_realm": "seaIce", - "standard_name": "freshwater_flux_from_ice", + "standard_name": "water_flux_into_sea_water_from_sea_ice", "units": "kg m-2 s-1", "cell_methods": "area: time: mean where sea_ice (comment: mask=siconc or siconca)", "cell_measures": "area: areacello OR areacella", @@ -665,7 +665,7 @@ "siflswdbot": { "frequency": "mon", "modeling_realm": "seaIce", - "standard_name": "bottom_downwelling_shortwave_flux_into_ocean", + "standard_name": "downwelling_shortwave_flux_in_sea_water_at_sea_ice_base", "units": "W m-2", "cell_methods": "area: time: mean where sea_ice (comment: mask=siconc or siconca)", "cell_measures": "area: areacello OR areacella", @@ -719,7 +719,7 @@ "siforcecoriolx": { "frequency": "mon", "modeling_realm": "seaIce", - "standard_name": "coriolis_force_on_sea_ice_x", + "standard_name": "sea_ice_specific_x_force_due_to_coriolis_term", "units": "N m-2", "cell_methods": "area: time: mean where sea_ice (comment: mask=siconc)", "cell_measures": "--MODEL", @@ -737,7 +737,7 @@ "siforcecorioly": { "frequency": "mon", "modeling_realm": "seaIce", - "standard_name": "coriolis_force_on_sea_ice_y", + "standard_name": "sea_ice_specific_y_force_due_to_coriolis_term", "units": "N m-2", "cell_methods": "area: time: mean where sea_ice (comment: mask=siconc)", "cell_measures": "--MODEL", @@ -755,7 +755,7 @@ "siforceintstrx": { "frequency": "mon", "modeling_realm": "seaIce", - "standard_name": "internal_stress_in_sea_ice_x", + "standard_name": "sea_ice_specific_x_force_due_to_internal_forces", "units": "N m-2", "cell_methods": "area: time: mean where sea_ice (comment: mask=siconc)", "cell_measures": "--MODEL", @@ -773,7 +773,7 @@ "siforceintstry": { "frequency": "mon", "modeling_realm": "seaIce", - "standard_name": "internal_stress_in_sea_ice_y", + "standard_name": "sea_ice_specific_y_force_due_to_internal_forces", "units": "N m-2", "cell_methods": "area: time: mean where sea_ice (comment: mask=siconc)", "cell_measures": "--MODEL", @@ -791,7 +791,7 @@ "siforcetiltx": { "frequency": "mon", "modeling_realm": "seaIce", - "standard_name": "sea_surface_tilt_force_on_sea_ice_x", + "standard_name": "sea_ice_specific_x_force_due_to_sea_surface_tilt", "units": "N m-2", "cell_methods": "area: time: mean where sea_ice (comment: mask=siconc)", "cell_measures": "--MODEL", @@ -809,7 +809,7 @@ "siforcetilty": { "frequency": "mon", "modeling_realm": "seaIce", - "standard_name": "sea_surface_tilt_force_on_sea_ice_y", + "standard_name": "sea_ice_specific_y_force_due_to_sea_surface_tilt", "units": "N m-2", "cell_methods": "area: time: mean where sea_ice (comment: mask=siconc)", "cell_measures": "--MODEL", @@ -971,7 +971,7 @@ "simpmass": { "frequency": "mon", "modeling_realm": "seaIce", - "standard_name": "surface_liquid_water_amount", + "standard_name": "sea_ice_melt_pond_thickness", "units": "kg m-2", "cell_methods": "area: time: mean where sea_ice_melt_pond (comment: mask=simpconc)", "cell_measures": "area: areacello", @@ -989,7 +989,7 @@ "simprefrozen": { "frequency": "mon", "modeling_realm": "seaIce", - "standard_name": "melt_pond_refrozen_ice", + "standard_name": "thickness_of_ice_on_sea_ice_melt_pond", "units": "m", "cell_methods": "area: time: mean where sea_ice_melt_pond (comment: mask=simpconc)", "cell_measures": "area: areacello", @@ -1079,7 +1079,7 @@ "sisaltmass": { "frequency": "mon", "modeling_realm": "seaIce", - "standard_name": "sea_ice_salt_mass", + "standard_name": "sea_ice_salt_content", "units": "kg m-2", "cell_methods": "area: time: mean", "cell_measures": "area: areacella", @@ -1313,7 +1313,7 @@ "sitempbot": { "frequency": "mon", "modeling_realm": "seaIce", - "standard_name": "sea_ice_bottom_temperature", + "standard_name": "sea_ice_basal_temperature", "units": "K", "cell_methods": "area: time: mean where sea_ice (comment: mask=siconc or siconca)", "cell_measures": "area: areacello OR areacella", @@ -1583,7 +1583,7 @@ "sndmasswindrif": { "frequency": "mon", "modeling_realm": "seaIce", - "standard_name": "tendency_of_snow_mass_due_to_drifting_snow", + "standard_name": "tendency_of_surface_snow_amount_due_to_drifting", "units": "kg m-2 s-1", "cell_methods": "area: time: mean", "cell_measures": "area: areacella", diff --git a/TestTables/CMIP6_coordinate.json b/TestTables/CMIP6_coordinate.json index 211d6683..689272c7 100644 --- a/TestTables/CMIP6_coordinate.json +++ b/TestTables/CMIP6_coordinate.json @@ -414,7 +414,7 @@ "stored_direction": "increasing", "tolerance": "", "type": "double", - "valid_max": "2200.0", + "valid_max": "2020.0", "valid_min": "1980.0", "value": "2000", "z_bounds_factors": "", @@ -681,6 +681,28 @@ "z_factors": "", "bounds_values": "" }, + "lambda550nm": { + "standard_name": "radiation_wavelength", + "units": "nm", + "axis": "", + "long_name": "Radiation Wavelength 550 nanometers", + "climatology": "", + "formula": "", + "must_have_bounds": "yes", + "out_name": "wavelength", + "positive": "", + "requested": "", + "requested_bounds": "", + "stored_direction": "", + "tolerance": "", + "type": "double", + "valid_max": "", + "valid_min": "", + "value": "550.0", + "z_bounds_factors": "", + "z_factors": "", + "bounds_values": "" + }, "landUse": { "standard_name": "area_type", "units": "", @@ -1735,10 +1757,10 @@ "type": "double", "valid_max": "", "valid_min": "", - "value": "0.005, 0.605, 2.1, 4, 6, 8.5, 12.5, 17.5, 22.5, 27.5, 35, 45, 55, 70, 50040", + "value": "", "z_bounds_factors": "", "z_factors": "", - "bounds_values": "0.0 0.01 1.2 3.0 5.0 7.0 10.0 15.0 20.0 25.0 30.0 40.0 50.0 60.0 80.0 100000.0" + "bounds_values": "" }, "sdepth": { "standard_name": "depth", @@ -1777,13 +1799,35 @@ "stored_direction": "increasing", "tolerance": "", "type": "double", - "valid_max": "0.2", + "valid_max": "0.1", "valid_min": "0.0", "value": "0.05", "z_bounds_factors": "", "z_factors": "", "bounds_values": "0.0 0.1" }, + "sdepth10": { + "standard_name": "depth", + "units": "m", + "axis": "Z", + "long_name": "depth", + "climatology": "", + "formula": "", + "must_have_bounds": "yes", + "out_name": "depth", + "positive": "down", + "requested": "", + "requested_bounds": "", + "stored_direction": "increasing", + "tolerance": "", + "type": "double", + "valid_max": "1.0", + "valid_min": "0.0", + "value": "0.5", + "z_bounds_factors": "", + "z_factors": "", + "bounds_values": "0.0 1.0" + }, "siline": { "standard_name": "region", "units": "", @@ -2721,7 +2765,7 @@ "bounds_values": "" }, "typewetla": { - "standard_name": "area_type", + "standard_name": "", "units": "", "axis": "", "long_name": "Wetland", @@ -2737,7 +2781,7 @@ "type": "character", "valid_max": "", "valid_min": "", - "value": "", + "value": "wetlands", "z_bounds_factors": "", "z_factors": "", "bounds_values": "" @@ -2746,7 +2790,7 @@ "standard_name": "", "units": "", "axis": "", - "long_name": "plant functional type", + "long_name": "Vegetation or Land Cover Type", "climatology": "", "formula": "", "must_have_bounds": "no", diff --git a/TestTables/CMIP6_day.json b/TestTables/CMIP6_day.json index 3c62ae87..766fbec0 100644 --- a/TestTables/CMIP6_day.json +++ b/TestTables/CMIP6_day.json @@ -1,10 +1,10 @@ { "Header": { - "data_specs_version": "01.00.21", + "data_specs_version": "01.00.23", + "cmor_version": "3.3", "table_id": "Table day", "realm": "atmos", - "cmor_version": "3.2", - "table_date": "14 February 2018", + "table_date": "21 March 2018", "missing_value": "1e20", "int_missing_value": "-999", "product": "model-output", @@ -40,7 +40,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "Surface Upward Latent Heat Flux", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'Upward' indicates a vector component which is positive when directed upward (negative downward). The surface latent heat flux is the exchange of heat between the surface and the air on account of evaporation (including sublimation). In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "longitude latitude time", "out_name": "hfls", "type": "real", @@ -58,7 +58,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "Surface Upward Sensible Heat Flux", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'Upward' indicates a vector component which is positive when directed upward (negative downward). The surface sensible heat flux, also called 'turbulent' heat flux, is the exchange of heat between the surface and the air by motion of air. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics. Unless indicated in the cell_methods attribute, a quantity is assumed to apply to the whole area of each horizontal grid box. Previously, the qualifier where_type was used to specify that the quantity applies only to the part of the grid box of the named type. Names containing the where_type qualifier are deprecated and newly created data should use the cell_methods attribute to indicate the horizontal area to which the quantity applies.", "dimensions": "longitude latitude time", "out_name": "hfss", "type": "real", @@ -148,7 +148,7 @@ "cell_methods": "time: mean", "cell_measures": "area: areacella", "long_name": "Specific Humidity", - "comment": "", + "comment": "'specific' means per unit mass. Specific humidity is the mass fraction of water vapor in (moist) air.", "dimensions": "longitude latitude plev8 time", "out_name": "hus", "type": "real", @@ -310,7 +310,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "Surface Downwelling Longwave Radiation", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'longwave' means longwave radiation. Downwelling radiation is radiation from above. It does not mean 'net downward'. When thought of as being incident on a surface, a radiative flux is sometimes called 'irradiance'. In addition, it is identical with the quantity measured by a cosine-collector light-meter and sometimes called 'vector irradiance'. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "longitude latitude time", "out_name": "rlds", "type": "real", @@ -328,7 +328,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "Surface Upwelling Longwave Radiation", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'longwave' means longwave radiation. Upwelling radiation is radiation from below. It does not mean 'net upward'. When thought of as being incident on a surface, a radiative flux is sometimes called 'irradiance'. In addition, it is identical with the quantity measured by a cosine-collector light-meter and sometimes called 'vector irradiance'. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "longitude latitude time", "out_name": "rlus", "type": "real", @@ -382,7 +382,7 @@ "cell_methods": "area: time: mean", "cell_measures": "area: areacella", "long_name": "Surface Upwelling Shortwave Radiation", - "comment": "", + "comment": "The surface called 'surface' means the lower boundary of the atmosphere. 'shortwave' means shortwave radiation. Upwelling radiation is radiation from below. It does not mean 'net upward'. When thought of as being incident on a surface, a radiative flux is sometimes called 'irradiance'. In addition, it is identical with the quantity measured by a cosine-collector light-meter and sometimes called 'vector irradiance'. In accordance with common usage in geophysical disciplines, 'flux' implies per unit area, called 'flux density' in physics.", "dimensions": "longitude latitude time", "out_name": "rsus", "type": "real", @@ -562,7 +562,7 @@ "cell_methods": "time: mean", "cell_measures": "area: areacella", "long_name": "Eastward Wind", - "comment": "", + "comment": "'Eastward' indicates a vector component which is positive when directed eastward (negative westward). Wind is defined as a two-dimensional (horizontal) air velocity vector, with no vertical component. (Vertical motion in the atmosphere has the standard name upward_air_velocity.)", "dimensions": "longitude latitude plev8 time", "out_name": "ua", "type": "real", @@ -598,7 +598,7 @@ "cell_methods": "time: mean", "cell_measures": "area: areacella", "long_name": "Northward Wind", - "comment": "", + "comment": "'Northward' indicates a vector component which is positive when directed northward (negative southward). Wind is defined as a two-dimensional (horizontal) air velocity vector, with no vertical component. (Vertical motion in the atmosphere has the standard name upward_air_velocity.)", "dimensions": "longitude latitude plev8 time", "out_name": "va", "type": "real", @@ -652,7 +652,7 @@ "cell_methods": "time: mean", "cell_measures": "area: areacella", "long_name": "Geopotential Height", - "comment": "", + "comment": "Geopotential is the sum of the specific gravitational potential energy relative to the geoid and the specific centripetal potential energy. Geopotential height is the geopotential divided by the standard acceleration due to gravity. It is numerically similar to the altitude (or geometric height) and not to the quantity with standard name height, which is relative to the surface.", "dimensions": "longitude latitude plev8 time", "out_name": "zg", "type": "real", diff --git a/TestTables/CMIP6_formula_terms.json b/TestTables/CMIP6_formula_terms.json index 9e502502..e8ebe7cd 100644 --- a/TestTables/CMIP6_formula_terms.json +++ b/TestTables/CMIP6_formula_terms.json @@ -19,7 +19,7 @@ "units": "Pa", "dimensions": "", "out_name": "p0", - "type": "" + "type": "double" }, "b": { "long_name": "vertical coordinate formula term: b(k)", @@ -61,14 +61,14 @@ "units": "m", "dimensions": "", "out_name": "ztop", - "type": "" + "type": "double" }, "ptop": { "long_name": "pressure at top of model", "units": "Pa", "dimensions": "", "out_name": "ptop", - "type": "" + "type": "double" }, "a_bnds": { "long_name": "vertical coordinate formula term: a(k+1/2)", diff --git a/TestTables/CMIP6_fx.json b/TestTables/CMIP6_fx.json index 402b249b..f65e47b5 100644 --- a/TestTables/CMIP6_fx.json +++ b/TestTables/CMIP6_fx.json @@ -1,10 +1,10 @@ { "Header": { - "data_specs_version": "01.00.21", + "data_specs_version": "01.00.23", + "cmor_version": "3.3", "table_id": "Table fx", "realm": "land", - "cmor_version": "3.2", - "table_date": "14 February 2018", + "table_date": "21 March 2018", "missing_value": "1e20", "int_missing_value": "-999", "product": "model-output", @@ -148,7 +148,7 @@ "cell_methods": "area: mean", "cell_measures": "area: areacella", "long_name": "Altitude of Model Full-Levels", - "comment": "", + "comment": "'Height_above_X' means the vertical distance above the named surface X. A reference ellipsoid is a mathematical figure that approximates the geoid. The geoid is a surface of constant geopotential with which mean sea level would coincide if the ocean were at rest. The ellipsoid is an approximation because the geoid is an irregular shape. A number of reference ellipsoids are defined for use in the field of geodesy. To specify which reference ellipsoid is being used, a grid_mapping variable should be attached to the data variable as described in Chapter 5.6 of the CF Convention.", "dimensions": "longitude latitude alevel", "out_name": "zfull", "type": "real", diff --git a/TestTables/CMIP6_grids.json b/TestTables/CMIP6_grids.json index 285c9189..029d3cab 100644 --- a/TestTables/CMIP6_grids.json +++ b/TestTables/CMIP6_grids.json @@ -1,12 +1,12 @@ { "Header": { "product": "output", - "cmor_version": "3.2", + "cmor_version": "3.3", "Conventions": "CF-1.7 CMIP-6.2", "table_id": "Table grids", - "data_specs_version": "01.00.21", + "data_specs_version": "01.00.23", "missing_value": "1e20", - "table_date": "14 February 2018" + "table_date": "21 March 2018" }, "mapping_entry": { "sample_user_mapping": { diff --git a/configure b/configure index 607987e8..212baa4f 100755 --- a/configure +++ b/configure @@ -1,6 +1,6 @@ #! /bin/sh # Guess values for system-dependent variables and create Makefiles. -# Generated by GNU Autoconf 2.69 for cmor 3.3.1. +# Generated by GNU Autoconf 2.69 for cmor 3.3.2. # # Report bugs to . # @@ -580,8 +580,8 @@ MAKEFLAGS= # Identity of this package. PACKAGE_NAME='cmor' PACKAGE_TARNAME='cmor' -PACKAGE_VERSION='3.3.1' -PACKAGE_STRING='cmor 3.3.1' +PACKAGE_VERSION='3.3.2' +PACKAGE_STRING='cmor 3.3.2' PACKAGE_BUGREPORT='nadeau1@llnl.gov' PACKAGE_URL='' @@ -1261,7 +1261,7 @@ if test "$ac_init_help" = "long"; then # Omit some internal or obsolete options to make the list less imposing. # This message is too long to be a string in the A/UX 3.1 sh. cat <<_ACEOF -\`configure' configures cmor 3.3.1 to adapt to many kinds of systems. +\`configure' configures cmor 3.3.2 to adapt to many kinds of systems. Usage: $0 [OPTION]... [VAR=VALUE]... @@ -1328,7 +1328,7 @@ fi if test -n "$ac_init_help"; then case $ac_init_help in - short | recursive ) echo "Configuration of cmor 3.3.1:";; + short | recursive ) echo "Configuration of cmor 3.3.2:";; esac cat <<\_ACEOF @@ -1430,7 +1430,7 @@ fi test -n "$ac_init_help" && exit $ac_status if $ac_init_version; then cat <<\_ACEOF -cmor configure 3.3.1 +cmor configure 3.3.2 generated by GNU Autoconf 2.69 Copyright (C) 2012 Free Software Foundation, Inc. @@ -1648,7 +1648,7 @@ cat >config.log <<_ACEOF This file contains any messages produced by compilers while running configure, to aid debugging if configure makes a mistake. -It was created by cmor $as_me 3.3.1, which was +It was created by cmor $as_me 3.3.2, which was generated by GNU Autoconf 2.69. Invocation command line was $ $0 $@ @@ -4979,7 +4979,7 @@ cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 # report actual input values of CONFIG_FILES etc. instead of their # values after options handling. ac_log=" -This file was extended by cmor $as_me 3.3.1, which was +This file was extended by cmor $as_me 3.3.2, which was generated by GNU Autoconf 2.69. Invocation command line was CONFIG_FILES = $CONFIG_FILES @@ -5032,7 +5032,7 @@ _ACEOF cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 ac_cs_config="`$as_echo "$ac_configure_args" | sed 's/^ //; s/[\\""\`\$]/\\\\&/g'`" ac_cs_version="\\ -cmor config.status 3.3.1 +cmor config.status 3.3.2 configured by $0, generated by GNU Autoconf 2.69, with options \\"\$ac_cs_config\\" diff --git a/configure.ac b/configure.ac index a7d3ac9f..73cc8f26 100644 --- a/configure.ac +++ b/configure.ac @@ -2,7 +2,7 @@ dnl dnl Process this file with autoconf to produce a configure script. dnl AC_PREREQ(2.59) -AC_INIT(cmor, 3.3.1, nadeau1@llnl.gov) +AC_INIT(cmor, 3.3.2, nadeau1@llnl.gov) GIT_TAG=`cd $srcdir ; ./get_git_version.sh` diff --git a/include/cmor.h b/include/cmor.h index 740dc33b..b54c2c59 100644 --- a/include/cmor.h +++ b/include/cmor.h @@ -3,7 +3,7 @@ #define CMOR_VERSION_MAJOR 3 #define CMOR_VERSION_MINOR 3 -#define CMOR_VERSION_PATCH 1 +#define CMOR_VERSION_PATCH 2 #define CMOR_CF_VERSION_MAJOR 1 #define CMOR_CF_VERSION_MINOR 6