eccodes/definitions/grib2/templates/template.3.30.def

100 lines
3.9 KiB
Modula-2
Raw Normal View History

2020-01-28 14:32:34 +00:00
# (C) Copyright 2005- ECMWF.
2013-03-25 12:04:10 +00:00
# TEMPLATE 3.30, Lambert conformal
include "grib2/templates/template.3.shape_of_the_earth.def"
2013-03-25 12:04:10 +00:00
constant isGridded = true;
unsigned[4] Nx : dump;
alias Ni = Nx;
alias numberOfPointsAlongXAxis = Nx;
2013-03-25 12:04:10 +00:00
alias geography.Nx=Nx;
unsigned[4] Ny : dump;
alias Nj = Ny;
alias numberOfPointsAlongYAxis = Nj;
alias numberOfPointsAlongAMeridian = Nj;
2013-03-25 12:04:10 +00:00
alias geography.Ny=Ny;
# La1 - latitude of first grid point
2013-03-25 12:04:10 +00:00
signed[4] latitudeOfFirstGridPoint : edition_specific;
alias La1 = latitudeOfFirstGridPoint;
meta geography.latitudeOfFirstGridPointInDegrees
2013-03-25 12:04:10 +00:00
scale(latitudeOfFirstGridPoint,one,grib2divider,truncateDegrees) : dump;
alias La1InDegrees=latitudeOfFirstGridPointInDegrees;
#meta latitudeOfFirstGridPointInMicrodegrees times(latitudeOfFirstGridPointInDegrees,oneConstant): no_copy;
# Lo1 - longitude of first grid point
2013-03-25 12:04:10 +00:00
unsigned[4] longitudeOfFirstGridPoint : edition_specific;
alias Lo1 = longitudeOfFirstGridPoint;
meta geography.longitudeOfFirstGridPointInDegrees
2013-03-25 12:04:10 +00:00
scale(longitudeOfFirstGridPoint,one,grib2divider,truncateDegrees) : dump;
alias Lo1InDegrees = longitudeOfFirstGridPointInDegrees;
#meta longitudeOfFirstGridPointInMicrodegrees times(longitudeOfFirstGridPoint,oneConstant) : no_copy;
include "grib2/templates/template.3.resolution_flags.def"
2013-03-25 12:04:10 +00:00
# LaD - Latitude where Dx and Dy are specified
signed[4] LaD : edition_specific;
2013-03-25 12:04:10 +00:00
alias latitudeWhereDxAndDyAreSpecified=LaD;
meta geography.LaDInDegrees scale(LaD,one,grib2divider,truncateDegrees) : dump;
2013-03-25 12:04:10 +00:00
# LoV - Longitude of meridian parallel to Y-axis along which latitude increases as the Y-coordinate increases
2013-03-25 12:04:10 +00:00
unsigned[4] LoV : edition_specific;
meta geography.LoVInDegrees scale(LoV,one,grib2divider,truncateDegrees) : dump;
2013-03-25 12:04:10 +00:00
# Dx - X-direction grid length (in units of millimetres)
unsigned[4] Dx : edition_specific;
2013-03-25 12:04:10 +00:00
alias xDirectionGridLength=Dx;
alias Di = Dx;
meta geography.DxInMetres scale(Dx,one,thousand) : dump;
2013-03-25 12:04:10 +00:00
# Dy - Y-direction grid length (in units of millimetres)
unsigned[4] Dy : edition_specific;
alias yDirectionGridLength=Dy;
2013-03-25 12:04:10 +00:00
alias Dj = Dy;
meta geography.DyInMetres scale(Dy,one,thousand) : dump;
2013-03-25 12:04:10 +00:00
# Projection centre flag
2013-03-25 12:04:10 +00:00
flags[1] projectionCentreFlag 'grib2/tables/[tablesVersion]/3.5.table' : dump;
include "grib2/templates/template.3.scanning_mode.def"
2013-03-25 12:04:10 +00:00
# Latin 1 - first latitude from the pole at which the secant cone cuts the sphere
2013-03-25 12:04:10 +00:00
signed[4] Latin1 : edition_specific;
alias firstLatitude=Latin1;
meta geography.Latin1InDegrees scale(Latin1,one,grib2divider,truncateDegrees) : dump;
2013-03-25 12:04:10 +00:00
# Latin 2 - second latitude from the pole at which the secant cone cuts the sphere
2013-03-25 12:04:10 +00:00
signed[4] Latin2 : dump;
alias secondLatitude=Latin2;
meta geography.Latin2InDegrees scale(Latin2,one,grib2divider,truncateDegrees) : dump;
2013-03-25 12:04:10 +00:00
# Latitude of the southern pole of projection
2013-03-25 12:04:10 +00:00
signed[4] latitudeOfSouthernPole : edition_specific;
alias latitudeOfTheSouthernPoleOfProjection=latitudeOfSouthernPole;
meta geography.latitudeOfSouthernPoleInDegrees scale(latitudeOfSouthernPole,one,grib2divider,truncateDegrees) : dump;
2013-03-25 12:04:10 +00:00
# Longitude of the southern pole of projection
2013-03-25 12:04:10 +00:00
unsigned[4] longitudeOfSouthernPole : edition_specific;
alias longitudeOfTheSouthernPoleOfProjection=longitudeOfSouthernPole;
meta geography.longitudeOfSouthernPoleInDegrees scale(longitudeOfSouthernPole,oneConstant,grib2divider,truncateDegrees) : dump;
2013-03-25 12:04:10 +00:00
iterator lambert_conformal(numberOfPoints,missingValue,values,
radius,Nx,Ny,
LoVInDegrees,LaDInDegrees,
Latin1InDegrees,Latin2InDegrees,
latitudeOfFirstGridPointInDegrees,longitudeOfFirstGridPointInDegrees,
DxInMetres,DyInMetres,
iScansNegatively, jScansPositively,
jPointsAreConsecutive, alternativeRowScanning);
2013-03-25 12:04:10 +00:00
nearest lambert_conformal(values,radius,Nx,Ny);
2013-03-25 12:04:10 +00:00
meta latLonValues latlonvalues(values);
alias latitudeLongitudeValues=latLonValues;
meta latitudes latitudes(values,0);
meta longitudes longitudes(values,0);
meta distinctLatitudes latitudes(values,1);
meta distinctLongitudes longitudes(values,1);