mirror of https://github.com/ecmwf/eccodes.git
104 lines
4.5 KiB
Modula-2
104 lines
4.5 KiB
Modula-2
# (C) Copyright 2005- ECMWF.
|
|
|
|
# Local definition 41 - The Flood Awareness System
|
|
|
|
# isFillup can be 0, 1 or missing
|
|
# When it is 0, it means "Water Balance"
|
|
unsigned[1] isFillup = missing() : dump, can_be_missing;
|
|
alias local.isFillup = isFillup;
|
|
|
|
# Forecast Reference Date and Time
|
|
# ECC-1264: When isFillup is missing, these should also be set to missing
|
|
# and dateOfForecast, timeOfForecast, anoffset are not relevant
|
|
unsigned[2] yearOfForecast = year : dump, can_be_missing;
|
|
unsigned[1] monthOfForecast = month : dump, can_be_missing;
|
|
unsigned[1] dayOfForecast = day : dump, can_be_missing;
|
|
unsigned[1] hourOfForecast = hour : dump, can_be_missing;
|
|
unsigned[1] minuteOfForecast = minute : dump, can_be_missing;
|
|
constant secondOfForecast = 0;
|
|
meta dateOfForecast g2date(yearOfForecast,monthOfForecast, dayOfForecast) : dump;
|
|
meta timeOfForecast time (hourOfForecast,minuteOfForecast,secondOfForecast) : dump;
|
|
|
|
# Calculate the Julian number for the forecast date and time.
|
|
# This will be a floating point number with units of 'day'
|
|
meta julianForecastDay julian_day(dateOfForecast,hourOfForecast,minuteOfForecast,secondOfForecast): hidden;
|
|
# Calculate the difference between the forecast date and reference date
|
|
transient diffInDays = (julianForecastDay - julianDay) : hidden; # float
|
|
|
|
# Now convert this to hours. First convert to minutes then round up
|
|
transient diffInHours = (diffInDays * 1440 + 0.5)/60 : hidden;
|
|
meta _anoffset round(diffInHours, 10): dump,long_type;
|
|
transient anoffset = _anoffset; # needed to force anoffset to be integer
|
|
alias local.anoffset = anoffset;
|
|
|
|
|
|
# ECC-662
|
|
unsigned[2] anoffsetFirst = missing(): dump, can_be_missing;
|
|
unsigned[2] anoffsetLast = missing(): dump, can_be_missing;
|
|
unsigned[2] anoffsetFrequency = missing(): dump, can_be_missing;
|
|
|
|
# Boolean
|
|
remove is_efas;
|
|
transient is_efas = 1;
|
|
transient lsdate_bug = 1: hidden; # See ECC-707
|
|
|
|
# Note: the key typeOfPostProcessing is in the PDTNs 70, 71, 72 and 73
|
|
concept efas_post_proc {
|
|
"unknown" = { typeOfPostProcessing = 0; }
|
|
"lisflood" = { typeOfPostProcessing = 1; }
|
|
"lisflood_eric" = { typeOfPostProcessing = 2; }
|
|
"lisflood_season" = { typeOfPostProcessing = 3; }
|
|
"lisflood_merged" = { typeOfPostProcessing = 4; }
|
|
"lisflood_global" = { typeOfPostProcessing = 5; }
|
|
"geff" = { typeOfPostProcessing = 10; }
|
|
"ericha" = { typeOfPostProcessing = 51; }
|
|
"htessel_lisflood" = { typeOfPostProcessing = 101; }
|
|
"htessel_eric" = { typeOfPostProcessing = 102; }
|
|
"htessel_camaflood" = { typeOfPostProcessing = 103; }
|
|
"epic" = { typeOfPostProcessing = 152; }
|
|
"jules_mrm" = { typeOfPostProcessing = 201; }
|
|
"htessel_mrm" = { typeOfPostProcessing = 202; }
|
|
"mhm_mrm" = { typeOfPostProcessing = 203; }
|
|
"pcrg_mrm" = { typeOfPostProcessing = 204; }
|
|
"meteogrid" = { typeOfPostProcessing = 205; }
|
|
"unknown" = { dummy = 1; }
|
|
} : hidden;
|
|
|
|
#Domain. Missing, local or global
|
|
#codetable[1] efasDomain "grib2/tables/local/ecmf/efas_domain.table" = 255 : dump, string_type;
|
|
#unsigned[1] efas_domain = missing() : can_be_missing, dump;
|
|
#concept efasDomain(unknown) {
|
|
# "local" = { efas_domain = 0; }
|
|
# "global" = { efas_domain = 1; }
|
|
#} : hidden;
|
|
|
|
# Model Cycle Date/Time
|
|
# This is the date of the new official implementation of the EFAS cycle.
|
|
unsigned[2] yearOfModelVersion = 0 : dump;
|
|
unsigned[1] monthOfModelVersion = 0 : dump;
|
|
unsigned[1] dayOfModelVersion = 0 : dump;
|
|
unsigned[1] hourOfModelVersion = 0 : dump;
|
|
unsigned[1] minuteOfModelVersion = 0 : dump;
|
|
constant secondOfModelVersion = 0;
|
|
meta dateOfModelVersion g2date(yearOfModelVersion, monthOfModelVersion, dayOfModelVersion) : dump;
|
|
meta timeOfModelVersion time (hourOfModelVersion, minuteOfModelVersion, secondOfModelVersion) : dump;
|
|
|
|
# Note: the key inputOriginatingCentre is in the PDTNs 70, 71, 72 and 73
|
|
#concept efas_forecast {
|
|
# "griddedobs" = { inputOriginatingCentre=98; marsType = "an"; }
|
|
# # "reanalysis" = { inputOriginatingCentre=98; marsType = "an"; }
|
|
#
|
|
# "hres" = { inputOriginatingCentre=98; marsType = "fc"; } # deterministic
|
|
# "ens" = { inputOriginatingCentre=98; marsType = "pf"; } # ensemble
|
|
# "ens" = { inputOriginatingCentre=98; marsType = "cf"; } # ensemble
|
|
#
|
|
# DWD rules
|
|
# "global" = { inputOriginatingCentre=78; inputProcessIdentifier = 1; }
|
|
# "lam" = { inputOriginatingCentre=78; inputProcessIdentifier = 2; }
|
|
#
|
|
# TODO: For now anything coming from cnmc (COSMO) is local area
|
|
# "lam" = { inputOriginatingCentre=80; }
|
|
#
|
|
# "unknown" = { dummy = 1; }
|
|
#} : hidden;
|