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
|
2024-01-16 12:40:17 +00:00
|
|
|
include "grib2/template.3.shape_of_the_earth.def"
|
2013-03-25 12:04:10 +00:00
|
|
|
|
2023-11-22 10:51:00 +00:00
|
|
|
constant isGridded = true;
|
2023-08-03 14:15:26 +00:00
|
|
|
|
|
|
|
unsigned[4] Nx : dump;
|
2023-08-16 10:34:37 +00:00
|
|
|
alias Ni = Nx;
|
2023-08-03 14:15:26 +00:00
|
|
|
alias numberOfPointsAlongXAxis = Nx;
|
2013-03-25 12:04:10 +00:00
|
|
|
alias geography.Nx=Nx;
|
|
|
|
|
2023-08-16 10:34:37 +00:00
|
|
|
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;
|
|
|
|
|
2023-08-03 14:15:26 +00:00
|
|
|
# La1 - latitude of first grid point
|
2013-03-25 12:04:10 +00:00
|
|
|
signed[4] latitudeOfFirstGridPoint : edition_specific;
|
2023-08-03 14:15:26 +00:00
|
|
|
alias La1 = latitudeOfFirstGridPoint;
|
2020-05-16 11:54:03 +00:00
|
|
|
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;
|
|
|
|
|
2023-08-03 14:15:26 +00:00
|
|
|
# Lo1 - longitude of first grid point
|
2013-03-25 12:04:10 +00:00
|
|
|
unsigned[4] longitudeOfFirstGridPoint : edition_specific;
|
2023-08-03 14:15:26 +00:00
|
|
|
alias Lo1 = longitudeOfFirstGridPoint;
|
2020-05-16 11:54:03 +00:00
|
|
|
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;
|
|
|
|
|
2024-01-16 12:40:17 +00:00
|
|
|
include "grib2/template.3.resolution_flags.def"
|
2013-03-25 12:04:10 +00:00
|
|
|
|
2023-08-03 14:15:26 +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;
|
2020-05-16 11:54:03 +00:00
|
|
|
meta geography.LaDInDegrees scale(LaD,one,grib2divider,truncateDegrees) : dump;
|
2013-03-25 12:04:10 +00:00
|
|
|
|
2023-08-03 14:15:26 +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;
|
2020-05-16 11:54:03 +00:00
|
|
|
meta geography.LoVInDegrees scale(LoV,one,grib2divider,truncateDegrees) : dump;
|
2013-03-25 12:04:10 +00:00
|
|
|
|
2023-08-03 14:15:26 +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;
|
2020-05-16 11:54:03 +00:00
|
|
|
meta geography.DxInMetres scale(Dx,one,thousand) : dump;
|
2013-03-25 12:04:10 +00:00
|
|
|
|
2023-08-03 14:15:26 +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;
|
2020-05-16 11:54:03 +00:00
|
|
|
meta geography.DyInMetres scale(Dy,one,thousand) : dump;
|
2013-03-25 12:04:10 +00:00
|
|
|
|
2023-08-03 14:15:26 +00:00
|
|
|
# Projection centre flag
|
2013-03-25 12:04:10 +00:00
|
|
|
flags[1] projectionCentreFlag 'grib2/tables/[tablesVersion]/3.5.table' : dump;
|
|
|
|
|
2024-01-16 12:40:17 +00:00
|
|
|
include "grib2/template.3.scanning_mode.def"
|
2013-03-25 12:04:10 +00:00
|
|
|
|
2023-08-03 14:15:26 +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;
|
2024-02-14 20:29:46 +00:00
|
|
|
alias firstLatitude=Latin1;
|
2020-05-16 11:54:03 +00:00
|
|
|
meta geography.Latin1InDegrees scale(Latin1,one,grib2divider,truncateDegrees) : dump;
|
2013-03-25 12:04:10 +00:00
|
|
|
|
2023-08-03 14:15:26 +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;
|
2024-02-14 20:29:46 +00:00
|
|
|
alias secondLatitude=Latin2;
|
2020-05-16 11:54:03 +00:00
|
|
|
meta geography.Latin2InDegrees scale(Latin2,one,grib2divider,truncateDegrees) : dump;
|
2013-03-25 12:04:10 +00:00
|
|
|
|
2023-08-03 14:15:26 +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;
|
2020-05-16 11:54:03 +00:00
|
|
|
meta geography.latitudeOfSouthernPoleInDegrees scale(latitudeOfSouthernPole,one,grib2divider,truncateDegrees) : dump;
|
2013-03-25 12:04:10 +00:00
|
|
|
|
2023-08-03 14:15:26 +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;
|
2020-05-16 11:54:03 +00:00
|
|
|
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,
|
2020-05-16 11:54:03 +00:00
|
|
|
iScansNegatively, jScansPositively,
|
|
|
|
jPointsAreConsecutive, alternativeRowScanning);
|
2013-03-25 12:04:10 +00:00
|
|
|
|
2014-07-18 16:16:06 +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);
|
2020-05-16 11:54:03 +00:00
|
|
|
meta distinctLatitudes latitudes(values,1);
|
|
|
|
meta distinctLongitudes longitudes(values,1);
|