2020-01-28 14:32:34 +00:00
|
|
|
# (C) Copyright 2005- ECMWF.
|
2013-03-25 12:04:10 +00:00
|
|
|
|
|
|
|
# Type of first fixed surface
|
|
|
|
codetable[1] typeOfFirstFixedSurface ('4.5.table',masterDir,localDir) : dump,no_copy,edition_specific,string_type;
|
|
|
|
meta unitsOfFirstFixedSurface codetable_units(typeOfFirstFixedSurface) : dump;
|
|
|
|
meta nameOfFirstFixedSurface codetable_title(typeOfFirstFixedSurface) : dump;
|
|
|
|
|
|
|
|
# Scale factor of first fixed surface
|
|
|
|
signed[1] scaleFactorOfFirstFixedSurface = missing() : can_be_missing,dump,no_copy,edition_specific;
|
|
|
|
|
|
|
|
# Scaled value of first fixed surface
|
|
|
|
unsigned[4] scaledValueOfFirstFixedSurface = missing() : can_be_missing,dump,no_copy,edition_specific;
|
|
|
|
|
|
|
|
# Type of second fixed surface
|
|
|
|
codetable[1] typeOfSecondFixedSurface ('4.5.table',masterDir,localDir) = 255 : dump,no_copy,edition_specific;
|
2013-04-11 10:39:04 +00:00
|
|
|
meta unitsOfSecondFixedSurface codetable_units(typeOfSecondFixedSurface) : dump;
|
|
|
|
meta nameOfSecondFixedSurface codetable_title(typeOfSecondFixedSurface) : dump;
|
2013-03-25 12:04:10 +00:00
|
|
|
|
|
|
|
# Scale factor of second fixed surface
|
|
|
|
signed[1] scaleFactorOfSecondFixedSurface = missing() : can_be_missing,dump,no_copy,edition_specific;
|
|
|
|
|
|
|
|
# Scaled value of second fixed surface
|
|
|
|
unsigned[4] scaledValueOfSecondFixedSurface = missing() : can_be_missing,dump,no_copy,edition_specific;
|
|
|
|
|
|
|
|
transient pressureUnits="hPa";
|
|
|
|
|
2020-10-05 14:32:01 +00:00
|
|
|
concept_nofail vertical.typeOfLevel (unknown,"typeOfLevelConcept.def",conceptsDir2,conceptsDir1);
|
2013-03-25 12:04:10 +00:00
|
|
|
|
|
|
|
alias levelType=typeOfFirstFixedSurface;
|
|
|
|
|
2015-03-11 14:00:13 +00:00
|
|
|
if (typeOfSecondFixedSurface == 255) {
|
|
|
|
# Only one surface
|
2013-03-25 12:04:10 +00:00
|
|
|
meta level g2level(typeOfFirstFixedSurface,
|
|
|
|
scaleFactorOfFirstFixedSurface,
|
|
|
|
scaledValueOfFirstFixedSurface,
|
|
|
|
pressureUnits) :dump;
|
2015-03-11 14:00:13 +00:00
|
|
|
transient bottomLevel=level; # Do not use alias (see GRIB-725)
|
|
|
|
transient topLevel=level;
|
2013-03-25 12:04:10 +00:00
|
|
|
} else {
|
2015-03-11 14:00:13 +00:00
|
|
|
# Two surfaces
|
2013-03-25 12:04:10 +00:00
|
|
|
meta topLevel g2level(typeOfFirstFixedSurface,
|
|
|
|
scaleFactorOfFirstFixedSurface,
|
|
|
|
scaledValueOfFirstFixedSurface,
|
|
|
|
pressureUnits) :dump;
|
|
|
|
meta bottomLevel g2level(typeOfSecondFixedSurface,
|
|
|
|
scaleFactorOfSecondFixedSurface,
|
|
|
|
scaledValueOfSecondFixedSurface,
|
|
|
|
pressureUnits) :dump;
|
2015-03-11 14:00:13 +00:00
|
|
|
alias level=topLevel; # (see GRIB-725)
|
2022-02-22 17:27:41 +00:00
|
|
|
|
2013-03-25 12:04:10 +00:00
|
|
|
}
|
|
|
|
alias ls.level=level;
|
|
|
|
alias vertical.level=level;
|
|
|
|
alias vertical.bottomLevel=bottomLevel;
|
|
|
|
alias vertical.topLevel=topLevel;
|
|
|
|
|
|
|
|
alias extraDim=zero;
|
|
|
|
if (defined(extraDimensionPresent)) {
|
2013-07-23 17:06:45 +00:00
|
|
|
if (extraDimensionPresent) {
|
|
|
|
alias extraDim=one;
|
|
|
|
}
|
2013-03-25 12:04:10 +00:00
|
|
|
}
|
|
|
|
if (extraDim) {
|
2013-07-23 17:06:45 +00:00
|
|
|
alias mars.levelist = dimension;
|
|
|
|
alias mars.levtype = dimensionType;
|
2013-03-25 12:04:10 +00:00
|
|
|
} else {
|
2014-07-16 13:47:24 +00:00
|
|
|
# See GRIB-74 why we store the pressureUnits in a transient
|
|
|
|
transient tempPressureUnits=pressureUnits;
|
2013-07-23 17:06:45 +00:00
|
|
|
if (!(typeOfLevel is "surface")) {
|
2014-07-16 13:47:24 +00:00
|
|
|
if (tempPressureUnits is "Pa") {
|
2013-07-23 17:06:45 +00:00
|
|
|
meta marsLevel scale(level,one,hundred) : read_only;
|
|
|
|
alias mars.levelist=marsLevel;
|
|
|
|
} else {
|
|
|
|
alias mars.levelist = level;
|
|
|
|
}
|
|
|
|
}
|
2022-01-27 19:04:41 +00:00
|
|
|
# ECC-1333: levtype should be read-only in GRIB2
|
2022-02-02 12:08:30 +00:00
|
|
|
concept mars.levtype(unknown,"marsLevtypeConcept.def",conceptsDir2,conceptsDir1):no_copy;
|
2013-07-23 17:06:45 +00:00
|
|
|
# GRIB-372: levelist alias does not pertain to surface parameters
|
2021-10-07 15:40:35 +00:00
|
|
|
if (levtype is "sfc" || levtype is "o2d") {
|
2013-07-23 17:06:45 +00:00
|
|
|
unalias mars.levelist;
|
|
|
|
}
|
2013-03-25 12:04:10 +00:00
|
|
|
}
|
2018-12-17 17:07:12 +00:00
|
|
|
|
2022-08-04 11:59:24 +00:00
|
|
|
# See ECC-854, ECC-1435
|
2022-08-04 10:19:22 +00:00
|
|
|
if( (typeOfFirstFixedSurface == 151 && typeOfSecondFixedSurface == 151) ||
|
|
|
|
(typeOfFirstFixedSurface == 152 && typeOfSecondFixedSurface == 152) ||
|
|
|
|
(typeOfFirstFixedSurface == 114 && typeOfSecondFixedSurface == 114) ) {
|
2018-12-17 17:07:12 +00:00
|
|
|
alias mars.levelist = bottomLevel;
|
|
|
|
}
|
|
|
|
|
2013-03-25 12:04:10 +00:00
|
|
|
alias ls.typeOfLevel=typeOfLevel;
|