# (C) Copyright 2005- ECMWF. position offsetSection1; section_length[4] section1Length ; meta section1Pointer section_pointer(offsetSection1,section1Length,1); unsigned[1] numberOfSection = 1 :read_only; codetable[2] centre 'common/c-11.table' : dump,string_type; alias identificationOfOriginatingGeneratingCentre=centre; meta centreDescription codetable_title(centre); alias parameter.centre=centre; alias ls.centre=centre; alias originatingCentre=centre; unsigned[2] subCentre : dump; _if (subCentre==98 ) { alias centreForLocal=subCentre; } else { alias centreForLocal=centre; } codetable[1] tablesVersion 'grib2/tables/1.0.table' = tablesVersionLatestOfficial : edition_specific; alias gribMasterTablesVersionNumber=tablesVersion; transient masterDir="grib2/tables/[tablesVersion]"; if (tablesVersion > tablesVersionLatest) { transient masterDir="grib2/tables/[tablesVersionLatest]"; } when (tablesVersion!=255) { set masterDir="grib2/tables/[tablesVersion]"; } else { set masterDir="grib2/tables/4"; } codetable[1] localTablesVersion 'grib2/tables/local/[centreForLocal]/1.1.table' ; alias versionNumberOfGribLocalTables=localTablesVersion; transient localDir=""; if (localTablesVersion != 0 and localTablesVersion != 255) { transient localDir="grib2/tables/local/[centre]/[localTablesVersion]"; } # Significance of Reference Time codetable[1] significanceOfReferenceTime ('1.2.table',masterDir,localDir) = 1 : dump; # Year (4 digits) unsigned[2] year; unsigned[1] month; unsigned[1] day; unsigned[1] hour; unsigned[1] minute; unsigned[1] second; meta dataDate g2date(year,month,day) : dump; alias mars.date = dataDate; alias ls.date = dataDate; meta julianDay julian_day(dataDate,hour,minute,second) : edition_specific; meta dataTime time(hour,minute,second) : dump; alias mars.time = dataTime; # Production status of processed data in this GRIB message codetable[1] productionStatusOfProcessedData ('1.3.table',masterDir,localDir) : dump; # Type of processed data in this GRIB message codetable[1] typeOfProcessedData ('1.4.table',masterDir,localDir) = 255 : dump,string_type,no_fail; alias ls.dataType=typeOfProcessedData; meta md5Section1 md5(offsetSection1,section1Length); meta selectStepTemplateInterval select_step_template(productDefinitionTemplateNumber,0); # 0 -> not instant meta selectStepTemplateInstant select_step_template(productDefinitionTemplateNumber,1); # 1 -> instant transient stepTypeInternal="instant" : hidden,no_copy; concept stepType { "instant" = {selectStepTemplateInstant=1; stepTypeInternal="instant";} "avg" = {selectStepTemplateInterval=1; stepTypeInternal="avg";} "avgd" = {selectStepTemplateInterval=1; stepTypeInternal="avgd";} "accum" = {selectStepTemplateInterval=1; stepTypeInternal="accum";} "max" = {selectStepTemplateInterval=1; stepTypeInternal="max";} "min" = {selectStepTemplateInterval=1; stepTypeInternal="min";} "diff" = {selectStepTemplateInterval=1; stepTypeInternal="diff";} "sdiff" = {selectStepTemplateInterval=1; stepTypeInternal="sdiff";} "rms" = {selectStepTemplateInterval=1; stepTypeInternal="rms";} "sd" = {selectStepTemplateInterval=1; stepTypeInternal="sd";} "cov" = {selectStepTemplateInterval=1; stepTypeInternal="cov";} "ratio" = {selectStepTemplateInterval=1; stepTypeInternal="ratio";} "stdanom" = {selectStepTemplateInterval=1; stepTypeInternal="stdanom";} "sum" = {selectStepTemplateInterval=1; stepTypeInternal="sum";} "severity" = {selectStepTemplateInterval=1; stepTypeInternal="severity";} "mode" = {selectStepTemplateInterval=1; stepTypeInternal="mode";} } # 0=atmospheric chemical constituents # 1=atmospheric chemical constituents based on a distribution function # 2=atmospheric chemical constituents with source or sink meta is_chemical g2_chemical(productDefinitionTemplateNumber, stepType, 0); meta is_chemical_distfn g2_chemical(productDefinitionTemplateNumber, stepType, 1); meta is_chemical_srcsink g2_chemical(productDefinitionTemplateNumber, stepType, 2); # 0=aerosol # 1=optical properties of aerosol meta is_aerosol g2_aerosol(productDefinitionTemplateNumber, stepType, 0); meta is_aerosol_optical g2_aerosol(productDefinitionTemplateNumber, stepType, 1); transient setCalendarId = 0 ; transient deleteCalendarId = 0 ; alias calendarIdPresent = false; if ( ((section1Length > 21) or setCalendarId > 0) and deleteCalendarId == 0) { alias calendarIdPresent = present; codetable[2] calendarIdentificationTemplateNumber ('1.5.table',masterDir,localDir) : dump,string_type,no_fail; template calendarIdentification "grib2/template.1.[calendarIdentificationTemplateNumber:l].def"; } constant conceptsMasterDir="grib2" : hidden; constant conceptsLocalDirAll="grib2/localConcepts/[centre:s]" : hidden; constant conceptsLocalDirECMF="grib2/localConcepts/ecmf" : hidden; # ECC-806: Local concepts precedence order if (preferLocalConcepts) { constant conceptsDir1 = conceptsMasterDir : hidden; constant conceptsDir2 = conceptsLocalDirAll : hidden; } else { constant conceptsDir1 = conceptsLocalDirAll : hidden; constant conceptsDir2 = conceptsMasterDir : hidden; }