2018-01-02 11:31:02 +00:00
|
|
|
# Copyright 2005-2018 ECMWF.
|
2013-03-25 12:04:10 +00:00
|
|
|
#
|
|
|
|
# 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.
|
2016-05-25 15:04:22 +00:00
|
|
|
#
|
2013-03-25 12:04:10 +00:00
|
|
|
# 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.
|
|
|
|
#
|
|
|
|
|
2015-07-28 09:50:26 +00:00
|
|
|
include "grib2/template.3.grid.def";
|
2013-03-25 12:04:10 +00:00
|
|
|
|
|
|
|
# Di - i direction increment
|
|
|
|
unsigned[4] iDirectionIncrement : can_be_missing;
|
|
|
|
alias Di = iDirectionIncrement;
|
|
|
|
|
|
|
|
# N - number of parallels between a pole and the equator
|
|
|
|
unsigned[4] N : dump;
|
|
|
|
alias numberOfParallelsBetweenAPoleAndTheEquator=N ;
|
|
|
|
alias geography.N=N;
|
|
|
|
|
2015-07-28 09:50:26 +00:00
|
|
|
include "grib2/template.3.scanning_mode.def";
|
2013-03-25 12:04:10 +00:00
|
|
|
|
|
|
|
modify Ni : can_be_missing,dump;
|
|
|
|
|
|
|
|
meta g2grid g2grid(
|
|
|
|
latitudeOfFirstGridPoint,
|
|
|
|
longitudeOfFirstGridPoint,
|
|
|
|
latitudeOfLastGridPoint,
|
|
|
|
longitudeOfLastGridPoint,
|
|
|
|
iDirectionIncrement,
|
|
|
|
null,
|
|
|
|
basicAngleOfTheInitialProductionDomain,
|
|
|
|
subdivisionsOfBasicAngle
|
|
|
|
);
|
|
|
|
|
|
|
|
meta geography.latitudeOfFirstGridPointInDegrees g2latlon(g2grid,0) : dump;
|
|
|
|
meta geography.longitudeOfFirstGridPointInDegrees g2latlon(g2grid,1) : dump;
|
|
|
|
meta geography.latitudeOfLastGridPointInDegrees g2latlon(g2grid,2) : dump;
|
|
|
|
meta geography.longitudeOfLastGridPointInDegrees g2latlon(g2grid,3) : dump;
|
|
|
|
meta geography.iDirectionIncrementInDegrees g2latlon(g2grid,4,iDirectionIncrementGiven) : can_be_missing,dump;
|
|
|
|
|
2013-07-23 17:06:45 +00:00
|
|
|
meta global global_gaussian(N,Ni,iDirectionIncrement,
|
|
|
|
latitudeOfFirstGridPoint,
|
|
|
|
longitudeOfFirstGridPoint,
|
|
|
|
latitudeOfLastGridPoint,
|
|
|
|
longitudeOfLastGridPoint,
|
2015-04-09 12:26:07 +00:00
|
|
|
PLPresent, pl,
|
2013-07-23 17:06:45 +00:00
|
|
|
basicAngleOfTheInitialProductionDomain,
|
|
|
|
subdivisionsOfBasicAngle) = 0 : dump;
|
2013-03-25 12:04:10 +00:00
|
|
|
|
|
|
|
alias xFirst=longitudeOfFirstGridPointInDegrees;
|
|
|
|
alias yFirst=latitudeOfFirstGridPointInDegrees;
|
|
|
|
alias xLast=longitudeOfLastGridPointInDegrees;
|
|
|
|
alias yLast=latitudeOfLastGridPointInDegrees;
|
|
|
|
|
|
|
|
alias latitudeFirstInDegrees = latitudeOfFirstGridPointInDegrees;
|
|
|
|
alias longitudeFirstInDegrees = longitudeOfFirstGridPointInDegrees;
|
|
|
|
alias latitudeLastInDegrees = latitudeOfLastGridPointInDegrees;
|
|
|
|
alias longitudeLastInDegrees = longitudeOfLastGridPointInDegrees;
|
|
|
|
alias DiInDegrees = iDirectionIncrementInDegrees;
|
|
|
|
|
|
|
|
if(missing(Ni) && PLPresent == 1){
|
|
|
|
iterator gaussian_reduced(numberOfPoints,missingValue,values,
|
|
|
|
latitudeOfFirstGridPointInDegrees,longitudeOfFirstGridPointInDegrees,
|
|
|
|
latitudeOfLastGridPointInDegrees,longitudeOfLastGridPointInDegrees,
|
|
|
|
N,pl,Nj);
|
|
|
|
nearest reduced(values,radius,Nj,pl);
|
|
|
|
} else {
|
|
|
|
iterator gaussian(numberOfPoints,missingValue,values,
|
|
|
|
longitudeFirstInDegrees,DiInDegrees ,
|
|
|
|
Ni,Nj,iScansNegatively,
|
|
|
|
latitudeFirstInDegrees, latitudeLastInDegrees,
|
|
|
|
N,jScansPositively);
|
2015-04-20 15:08:04 +00:00
|
|
|
nearest regular(values,radius,Ni,Nj);
|
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);
|
2014-07-10 10:18:42 +00:00
|
|
|
|
2015-05-05 11:46:31 +00:00
|
|
|
meta isOctahedral octahedral_gaussian(N, Ni, PLPresent, pl) = 0 : no_copy,dump;
|
2015-04-20 15:08:04 +00:00
|
|
|
|
2015-11-26 16:58:01 +00:00
|
|
|
meta gaussianGridName gaussian_grid_name(N, Ni, isOctahedral);
|
|
|
|
alias gridName=gaussianGridName;
|
|
|
|
|
|
|
|
|
2014-07-10 10:18:42 +00:00
|
|
|
# Useful for sub-areas
|
|
|
|
# meta numberOfExpectedPoints number_of_points_gaussian(Ni,Nj,PLPresent,pl,
|
|
|
|
# N,
|
|
|
|
# latitudeOfFirstGridPointInDegrees,longitudeOfFirstGridPointInDegrees,
|
|
|
|
# latitudeOfLastGridPointInDegrees,longitudeOfLastGridPointInDegrees) : dump;
|
|
|
|
|