mirror of https://github.com/ecmwf/eccodes.git
Lambert azimuthal equal area: implement nearest
This commit is contained in:
parent
13ba76f3a8
commit
9e66dd4494
|
@ -60,6 +60,8 @@ iterator lambert_azimuthal_equal_area(numberOfPoints,missingValue,values,
|
||||||
iScansNegatively, jScansPositively,
|
iScansNegatively, jScansPositively,
|
||||||
jPointsAreConsecutive, alternativeRowScanning);
|
jPointsAreConsecutive, alternativeRowScanning);
|
||||||
|
|
||||||
|
nearest lambert_azimuthal_equal_area(values,radius,Nx,Ny);
|
||||||
|
|
||||||
meta latLonValues latlonvalues(values);
|
meta latLonValues latlonvalues(values);
|
||||||
alias latitudeLongitudeValues=latLonValues;
|
alias latitudeLongitudeValues=latLonValues;
|
||||||
meta latitudes latitudes(values,0);
|
meta latitudes latitudes(values,0);
|
||||||
|
|
|
@ -346,6 +346,7 @@ list( APPEND grib_api_srcs
|
||||||
grib_nearest_class_latlon_reduced.c
|
grib_nearest_class_latlon_reduced.c
|
||||||
grib_nearest_class_sh.c
|
grib_nearest_class_sh.c
|
||||||
grib_nearest_class_lambert_conformal.c
|
grib_nearest_class_lambert_conformal.c
|
||||||
|
grib_nearest_class_lambert_azimuthal_equal_area.c
|
||||||
grib_nearest_class_mercator.c
|
grib_nearest_class_mercator.c
|
||||||
grib_nearest_class_polar_stereographic.c
|
grib_nearest_class_polar_stereographic.c
|
||||||
grib_iterator_class_polar_stereographic.c
|
grib_iterator_class_polar_stereographic.c
|
||||||
|
|
|
@ -361,6 +361,7 @@ libeccodes_la_prototypes= \
|
||||||
grib_nearest_class_latlon_reduced.c \
|
grib_nearest_class_latlon_reduced.c \
|
||||||
grib_nearest_class_sh.c \
|
grib_nearest_class_sh.c \
|
||||||
grib_nearest_class_lambert_conformal.c \
|
grib_nearest_class_lambert_conformal.c \
|
||||||
|
grib_nearest_class_lambert_azimuthal_equal_area.c \
|
||||||
grib_nearest_class_mercator.c \
|
grib_nearest_class_mercator.c \
|
||||||
grib_nearest_class_polar_stereographic.c \
|
grib_nearest_class_polar_stereographic.c \
|
||||||
grib_iterator_class_polar_stereographic.c \
|
grib_iterator_class_polar_stereographic.c \
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
/* This file is automatically generated by ./make_class.pl, do not edit */
|
/* This file is automatically generated by ./make_class.pl, do not edit */
|
||||||
extern grib_nearest_class* grib_nearest_class_gen;
|
extern grib_nearest_class* grib_nearest_class_gen;
|
||||||
|
extern grib_nearest_class* grib_nearest_class_lambert_azimuthal_equal_area;
|
||||||
extern grib_nearest_class* grib_nearest_class_lambert_conformal;
|
extern grib_nearest_class* grib_nearest_class_lambert_conformal;
|
||||||
extern grib_nearest_class* grib_nearest_class_latlon_reduced;
|
extern grib_nearest_class* grib_nearest_class_latlon_reduced;
|
||||||
extern grib_nearest_class* grib_nearest_class_mercator;
|
extern grib_nearest_class* grib_nearest_class_mercator;
|
||||||
|
|
|
@ -0,0 +1,142 @@
|
||||||
|
/*
|
||||||
|
* (C) Copyright 2005- 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "grib_api_internal.h"
|
||||||
|
|
||||||
|
/*
|
||||||
|
This is used by make_class.pl
|
||||||
|
|
||||||
|
START_CLASS_DEF
|
||||||
|
CLASS = nearest
|
||||||
|
SUPER = grib_nearest_class_gen
|
||||||
|
IMPLEMENTS = init
|
||||||
|
IMPLEMENTS = find;destroy
|
||||||
|
MEMBERS = double* lats
|
||||||
|
MEMBERS = int lats_count
|
||||||
|
MEMBERS = double* lons
|
||||||
|
MEMBERS = int lons_count
|
||||||
|
MEMBERS = double* distances
|
||||||
|
MEMBERS = int* k
|
||||||
|
MEMBERS = int* i
|
||||||
|
MEMBERS = int* j
|
||||||
|
MEMBERS = const char* Ni
|
||||||
|
MEMBERS = const char* Nj
|
||||||
|
END_CLASS_DEF
|
||||||
|
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* START_CLASS_IMP */
|
||||||
|
|
||||||
|
/*
|
||||||
|
|
||||||
|
Don't edit anything between START_CLASS_IMP and END_CLASS_IMP
|
||||||
|
Instead edit values between START_CLASS_DEF and END_CLASS_DEF
|
||||||
|
or edit "nearest.class" and rerun ./make_class.pl
|
||||||
|
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
static void init_class(grib_nearest_class*);
|
||||||
|
|
||||||
|
static int init(grib_nearest* nearest, grib_handle* h, grib_arguments* args);
|
||||||
|
static int find(grib_nearest* nearest, grib_handle* h, double inlat, double inlon, unsigned long flags, double* outlats, double* outlons, double* values, double* distances, int* indexes, size_t* len);
|
||||||
|
static int destroy(grib_nearest* nearest);
|
||||||
|
|
||||||
|
typedef struct grib_nearest_lambert_azimuthal_equal_area
|
||||||
|
{
|
||||||
|
grib_nearest nearest;
|
||||||
|
/* Members defined in gen */
|
||||||
|
const char* values_key;
|
||||||
|
const char* radius;
|
||||||
|
int cargs;
|
||||||
|
/* Members defined in lambert_azimuthal_equal_area */
|
||||||
|
double* lats;
|
||||||
|
int lats_count;
|
||||||
|
double* lons;
|
||||||
|
int lons_count;
|
||||||
|
double* distances;
|
||||||
|
int* k;
|
||||||
|
int* i;
|
||||||
|
int* j;
|
||||||
|
const char* Ni;
|
||||||
|
const char* Nj;
|
||||||
|
} grib_nearest_lambert_azimuthal_equal_area;
|
||||||
|
|
||||||
|
extern grib_nearest_class* grib_nearest_class_gen;
|
||||||
|
|
||||||
|
static grib_nearest_class _grib_nearest_class_lambert_azimuthal_equal_area = {
|
||||||
|
&grib_nearest_class_gen, /* super */
|
||||||
|
"lambert_azimuthal_equal_area", /* name */
|
||||||
|
sizeof(grib_nearest_lambert_azimuthal_equal_area), /* size of instance */
|
||||||
|
0, /* inited */
|
||||||
|
&init_class, /* init_class */
|
||||||
|
&init, /* constructor */
|
||||||
|
&destroy, /* destructor */
|
||||||
|
&find, /* find nearest */
|
||||||
|
};
|
||||||
|
|
||||||
|
grib_nearest_class* grib_nearest_class_lambert_azimuthal_equal_area = &_grib_nearest_class_lambert_azimuthal_equal_area;
|
||||||
|
|
||||||
|
|
||||||
|
static void init_class(grib_nearest_class* c)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
/* END_CLASS_IMP */
|
||||||
|
|
||||||
|
static int init(grib_nearest* nearest, grib_handle* h, grib_arguments* args)
|
||||||
|
{
|
||||||
|
grib_nearest_lambert_azimuthal_equal_area* self = (grib_nearest_lambert_azimuthal_equal_area*)nearest;
|
||||||
|
self->Ni = grib_arguments_get_name(h, args, self->cargs++);
|
||||||
|
self->Nj = grib_arguments_get_name(h, args, self->cargs++);
|
||||||
|
self->i = (int*)grib_context_malloc(h->context, 2 * sizeof(int));
|
||||||
|
self->j = (int*)grib_context_malloc(h->context, 2 * sizeof(int));
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int find(grib_nearest* nearest, grib_handle* h,
|
||||||
|
double inlat, double inlon, unsigned long flags,
|
||||||
|
double* outlats, double* outlons,
|
||||||
|
double* values, double* distances, int* indexes, size_t* len)
|
||||||
|
{
|
||||||
|
grib_nearest_lambert_azimuthal_equal_area* self = (grib_nearest_lambert_azimuthal_equal_area*)nearest;
|
||||||
|
return grib_nearest_find_generic(
|
||||||
|
nearest, h, inlat, inlon, flags, /* inputs */
|
||||||
|
|
||||||
|
self->values_key, /* outputs to set the 'self' object */
|
||||||
|
self->radius,
|
||||||
|
&(self->lats),
|
||||||
|
&(self->lats_count),
|
||||||
|
&(self->lons),
|
||||||
|
&(self->lons_count),
|
||||||
|
&(self->distances),
|
||||||
|
self->Ni,
|
||||||
|
self->Nj,
|
||||||
|
|
||||||
|
outlats, outlons, /* outputs of the find function */
|
||||||
|
values, distances, indexes, len);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int destroy(grib_nearest* nearest)
|
||||||
|
{
|
||||||
|
grib_nearest_lambert_azimuthal_equal_area* self = (grib_nearest_lambert_azimuthal_equal_area*)nearest;
|
||||||
|
if (self->lats)
|
||||||
|
grib_context_free(nearest->context, self->lats);
|
||||||
|
if (self->lons)
|
||||||
|
grib_context_free(nearest->context, self->lons);
|
||||||
|
if (self->i)
|
||||||
|
grib_context_free(nearest->context, self->i);
|
||||||
|
if (self->j)
|
||||||
|
grib_context_free(nearest->context, self->j);
|
||||||
|
if (self->k)
|
||||||
|
grib_context_free(nearest->context, self->k);
|
||||||
|
if (self->distances)
|
||||||
|
grib_context_free(nearest->context, self->distances);
|
||||||
|
return GRIB_SUCCESS;
|
||||||
|
}
|
|
@ -1,5 +1,6 @@
|
||||||
/* This file is automatically generated by ./make_class.pl, do not edit */
|
/* This file is automatically generated by ./make_class.pl, do not edit */
|
||||||
{ "gen", &grib_nearest_class_gen, },
|
{ "gen", &grib_nearest_class_gen, },
|
||||||
|
{ "lambert_azimuthal_equal_area", &grib_nearest_class_lambert_azimuthal_equal_area, },
|
||||||
{ "lambert_conformal", &grib_nearest_class_lambert_conformal, },
|
{ "lambert_conformal", &grib_nearest_class_lambert_conformal, },
|
||||||
{ "latlon_reduced", &grib_nearest_class_latlon_reduced, },
|
{ "latlon_reduced", &grib_nearest_class_latlon_reduced, },
|
||||||
{ "mercator", &grib_nearest_class_mercator, },
|
{ "mercator", &grib_nearest_class_mercator, },
|
||||||
|
|
|
@ -55,5 +55,9 @@ diff $DATA_OUTFILE $REF_FILE
|
||||||
grib_check_key_equals $GRIB_OUTFILE standardParallelInDegrees,centralLongitudeInDegrees '48 9'
|
grib_check_key_equals $GRIB_OUTFILE standardParallelInDegrees,centralLongitudeInDegrees '48 9'
|
||||||
grib_check_key_equals $GRIB_OUTFILE xDirectionGridLengthInMetres,yDirectionGridLengthInMetres '5000 5000'
|
grib_check_key_equals $GRIB_OUTFILE xDirectionGridLengthInMetres,yDirectionGridLengthInMetres '5000 5000'
|
||||||
|
|
||||||
|
# Nearest
|
||||||
|
${tools_dir}/grib_ls -l 67,-33,1 $GRIB_OUTFILE
|
||||||
|
|
||||||
|
|
||||||
# Clean up
|
# Clean up
|
||||||
rm -f $FILTER_FILE $GRIB_OUTFILE $DATA_OUTFILE
|
rm -f $FILTER_FILE $GRIB_OUTFILE $DATA_OUTFILE
|
||||||
|
|
Loading…
Reference in New Issue