mirror of https://github.com/ecmwf/eccodes.git
140 lines
4.9 KiB
Modula-2
140 lines
4.9 KiB
Modula-2
# Copyright 2005-2014 ECMWF.
|
|
#
|
|
# This software is licensed under the terms of the Apache Licence Version 2.0
|
|
# which can be obtained at http://www.apache.org/licenses/LICENSE-2.0.
|
|
#
|
|
# In applying this licence, ECMWF does not waive the privileges and immunities granted to it by
|
|
# virtue of its status as an intergovernmental organisation nor does it submit to any jurisdiction.
|
|
#
|
|
|
|
# Predefined grid 21
|
|
|
|
#position offsetSection2;
|
|
#transient section2Length=0 ;
|
|
|
|
template predefined_grid_values "grib1/grid_[gridDefinition].def";
|
|
|
|
# NV -- number of vertical coordinate parameters
|
|
constant numberOfVerticalCoordinateValues=0 ;
|
|
|
|
constant neitherPresent = 255;
|
|
|
|
alias NV = numberOfVerticalCoordinateValues;
|
|
alias numberOfCoordinatesValues= numberOfVerticalCoordinateValues;
|
|
|
|
# PV -- location
|
|
# (octet number)
|
|
constant pvlLocation = 255;
|
|
|
|
# Data representation type
|
|
constant dataRepresentationType = 0;
|
|
|
|
# Grid definition
|
|
# (according to data representation type - octet 6 above)
|
|
|
|
# grib 1 -> 2
|
|
constant gridDefinitionTemplateNumber = 0;
|
|
|
|
# START 1/grid_definition.latitude_longitude_grid ----------------------------------------------------------------------
|
|
# GRID DEFINITION latitude/longitude grid (or equidistant cylindrical)
|
|
|
|
alias numberOfPointsAlongAParallel=Ni;
|
|
alias numberOfPointsAlongAMeridian=Nj;
|
|
|
|
# Latitudes and Longitudes of the first and the last points
|
|
# Resolution and component flags
|
|
|
|
# La1 - latitude of first grid point
|
|
meta geography.latitudeOfFirstGridPointInDegrees scale(latitudeOfFirstGridPoint,oneConstant,grib1divider,truncateDegrees) : read_only;
|
|
alias La1 = latitudeOfFirstGridPoint;
|
|
|
|
# Lo1 - longitude of first grid point
|
|
meta geography.longitudeOfFirstGridPointInDegrees scale(longitudeOfFirstGridPoint,oneConstant,grib1divider,truncateDegrees) : read_only;
|
|
alias Lo1 = longitudeOfFirstGridPoint;
|
|
|
|
# Resolution and component flags
|
|
constant resolutionAndComponentFlags = 128;
|
|
|
|
# Not flagbit numbers 7 to 0, while wmo is 1 to 8
|
|
constant ijDirectionIncrementGiven = 1 ;
|
|
|
|
# For grib 1 to 2
|
|
alias iDirectionIncrementGiven = ijDirectionIncrementGiven;
|
|
alias jDirectionIncrementGiven = ijDirectionIncrementGiven;
|
|
alias DiGiven = ijDirectionIncrementGiven;
|
|
alias DjGiven = ijDirectionIncrementGiven;
|
|
|
|
constant earthIsOblate = 0;
|
|
constant resolutionAndComponentFlags3 = 0;
|
|
constant resolutionAndComponentFlags4 = 0;
|
|
constant uvRelativeToGrid = 0;
|
|
constant resolutionAndComponentFlags6 = 0;
|
|
constant resolutionAndComponentFlags7 = 0;
|
|
constant resolutionAndComponentFlags8 = 0;
|
|
|
|
# La2 - latitude of last grid point
|
|
meta geography.latitudeOfLastGridPointInDegrees scale(latitudeOfLastGridPoint,oneConstant,grib1divider,truncateDegrees) : read_only;
|
|
alias La2 = latitudeOfLastGridPoint;
|
|
|
|
# Lo2 - longitude of last grid point
|
|
meta geography.longitudeOfLastGridPointInDegrees scale(longitudeOfLastGridPoint,oneConstant,grib1divider,truncateDegrees) : read_only;
|
|
alias Lo2 = longitudeOfLastGridPoint;
|
|
|
|
alias Dj = jDirectionIncrement;
|
|
alias Di = iDirectionIncrement;
|
|
|
|
# Scanning mode
|
|
constant scanningMode = 64;
|
|
|
|
# Not flagbit numbers 7 to 0, while wmo is 1 to 8
|
|
constant iScansNegatively = 0 ;
|
|
constant jScansPositively = 1 ;
|
|
constant jPointsAreConsecutive = 0;
|
|
constant iScansPositively = 1;
|
|
|
|
constant scanningMode4 = 0;
|
|
constant scanningMode5 = 0;
|
|
constant scanningMode6 = 0;
|
|
constant scanningMode7 = 0;
|
|
constant scanningMode8 = 0;
|
|
|
|
meta geography.jDirectionIncrementInDegrees latlon_increment(ijDirectionIncrementGiven,jDirectionIncrement,
|
|
jScansPositively,
|
|
latitudeOfFirstGridPointInDegrees,latitudeOfLastGridPointInDegrees,
|
|
numberOfPointsAlongAMeridian,oneConstant,grib1divider,0) : read_only;
|
|
|
|
meta geography.iDirectionIncrementInDegrees latlon_increment(ijDirectionIncrementGiven,iDirectionIncrement,
|
|
iScansPositively,
|
|
longitudeOfFirstGridPointInDegrees,longitudeOfLastGridPointInDegrees,
|
|
Ni,oneConstant,grib1divider,1) : read_only;
|
|
|
|
alias latitudeFirstInDegrees = latitudeOfFirstGridPointInDegrees;
|
|
alias longitudeFirstInDegrees = longitudeOfFirstGridPointInDegrees;
|
|
alias latitudeLastInDegrees = latitudeOfLastGridPointInDegrees;
|
|
alias longitudeLastInDegrees = longitudeOfLastGridPointInDegrees;
|
|
alias DiInDegrees = iDirectionIncrementInDegrees;
|
|
alias DjInDegrees = jDirectionIncrementInDegrees;
|
|
|
|
alias numberOfPoints=numberOfDataPoints;
|
|
#alias ls.valuesCount=numberOfValues;
|
|
|
|
# END 1/grid_definition.latitude_longitude_grid ----------------------------------------------------------------------
|
|
constant PVPresent = 0;
|
|
constant PLPresent = 0;
|
|
constant reducedGrid =0;
|
|
|
|
# we always include the bitmap keys if a GDS is not present
|
|
# Number of unused bits at end of Section 3
|
|
constant numberOfUnusedBitsAtEndOfSection3 = 0;
|
|
|
|
# Table reference:
|
|
constant tableReference = 0;
|
|
|
|
#position offsetBeforeBitmap;
|
|
meta bitmap gds_not_present_bitmap( missingValue,numberOfValues,
|
|
numberOfPoints,
|
|
latitudeOfFirstGridPoint,
|
|
Ni,numberOfUnusedBitsAtEndOfSection3) : read_only;
|
|
|
|
|