2013-03-25 12:04:10 +00:00
|
|
|
/*
|
2020-01-28 14:32:34 +00:00
|
|
|
* (C) Copyright 2005- 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.
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
2013-03-25 14:23:07 +00:00
|
|
|
* C Implementation: nearest
|
2013-03-25 12:04:10 +00:00
|
|
|
*
|
2019-12-12 18:00:56 +00:00
|
|
|
* Description: How to get nearest point(s).
|
|
|
|
* Assumes all input GRIB messages have the same grid geometry
|
2013-03-25 12:04:10 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
|
|
|
|
2014-12-23 10:16:21 +00:00
|
|
|
#include "eccodes.h"
|
2013-03-25 12:04:10 +00:00
|
|
|
|
2020-01-22 14:57:43 +00:00
|
|
|
static void usage(const char* prog)
|
|
|
|
{
|
|
|
|
printf("Usage: %s grib_file grib_file ...\n", prog);
|
2014-06-18 16:14:01 +00:00
|
|
|
exit(1);
|
2013-03-25 12:04:10 +00:00
|
|
|
}
|
|
|
|
|
2014-06-18 16:14:01 +00:00
|
|
|
int main(int argc, char** argv)
|
|
|
|
{
|
2020-01-22 14:57:43 +00:00
|
|
|
int err = 0;
|
|
|
|
long step = 0;
|
2019-12-14 21:37:13 +00:00
|
|
|
size_t nfiles;
|
2020-01-22 14:57:43 +00:00
|
|
|
int i = 0;
|
|
|
|
codes_fieldset* set = NULL;
|
|
|
|
codes_handle* h = NULL;
|
2022-02-25 18:15:44 +00:00
|
|
|
char shortName[20] = {0,};
|
2020-01-22 14:57:43 +00:00
|
|
|
size_t len = 20;
|
|
|
|
double lats[4] = {0,};
|
|
|
|
double lons[4] = {0,};
|
|
|
|
double values[4] = {0,};
|
|
|
|
double distances[4] = {0,};
|
|
|
|
int indexes[4] = {0,};
|
2022-04-08 15:30:32 +00:00
|
|
|
const char* order_by = "shortName,step:i";
|
2020-01-22 14:57:43 +00:00
|
|
|
|
|
|
|
size_t size = 4;
|
|
|
|
double lat = -40, lon = 15;
|
|
|
|
int mode = 0;
|
2014-06-18 16:14:01 +00:00
|
|
|
int count;
|
2022-06-30 09:28:04 +00:00
|
|
|
const char** filenames = NULL;
|
2020-01-22 14:57:43 +00:00
|
|
|
codes_nearest* nearest = NULL;
|
2014-06-18 16:14:01 +00:00
|
|
|
|
|
|
|
if (argc < 2) usage(argv[0]);
|
2019-12-12 17:33:56 +00:00
|
|
|
|
2020-01-22 14:57:43 +00:00
|
|
|
nfiles = argc - 1;
|
2022-06-30 09:28:04 +00:00
|
|
|
filenames = (const char**)malloc(sizeof(char*) * nfiles);
|
2020-01-22 14:57:43 +00:00
|
|
|
for (i = 0; i < nfiles; i++)
|
2022-06-30 09:28:04 +00:00
|
|
|
filenames[i] = strdup(argv[i + 1]);
|
2014-06-18 16:14:01 +00:00
|
|
|
|
2020-01-22 14:57:43 +00:00
|
|
|
set = codes_fieldset_new_from_files(0, filenames, nfiles, 0, 0, 0, order_by, &err);
|
|
|
|
CODES_CHECK(err, 0);
|
2013-03-25 12:04:10 +00:00
|
|
|
|
2020-01-22 14:57:43 +00:00
|
|
|
printf("\nordering by %s\n", order_by);
|
|
|
|
printf("\n%d fields in the fieldset\n", codes_fieldset_count(set));
|
2013-03-25 12:04:10 +00:00
|
|
|
|
2020-01-22 14:57:43 +00:00
|
|
|
mode = CODES_NEAREST_SAME_GRID | CODES_NEAREST_SAME_POINT;
|
|
|
|
count = 1;
|
2015-08-11 13:00:45 +00:00
|
|
|
|
2020-01-22 14:57:43 +00:00
|
|
|
while ((h = codes_fieldset_next_handle(set, &err)) != NULL) {
|
|
|
|
CODES_CHECK(codes_get_long(h, "step", &step), 0);
|
|
|
|
len = 20;
|
2022-02-25 18:15:44 +00:00
|
|
|
CODES_CHECK(codes_get_string(h, "shortName", shortName, &len), 0);
|
2013-03-25 12:04:10 +00:00
|
|
|
|
2022-02-25 18:15:44 +00:00
|
|
|
printf("Msg #%d, step=%ld, shortName=%s", count, step, shortName);
|
2020-01-22 14:57:43 +00:00
|
|
|
if (!nearest) nearest = codes_grib_nearest_new(h, &err);
|
|
|
|
CODES_CHECK(err, 0);
|
|
|
|
CODES_CHECK(codes_grib_nearest_find(nearest, h, lat, lon, mode, lats, lons, values, distances, indexes, &size), 0);
|
2019-12-14 21:37:13 +00:00
|
|
|
printf("\nIdx\tlat\tlon\tdist\tval\n");
|
2020-01-22 14:57:43 +00:00
|
|
|
for (i = 0; i < 4; i++)
|
|
|
|
printf("%d\t%.2f\t%.2f\t%g\t%g\n",
|
|
|
|
(int)indexes[i], lats[i], lons[i], distances[i], values[i]);
|
2014-06-18 16:14:01 +00:00
|
|
|
printf("\n");
|
2013-03-25 12:04:10 +00:00
|
|
|
|
2014-12-23 10:16:21 +00:00
|
|
|
codes_handle_delete(h);
|
2014-06-18 16:14:01 +00:00
|
|
|
count++;
|
|
|
|
}
|
|
|
|
|
2015-02-11 14:32:39 +00:00
|
|
|
if (nearest) codes_grib_nearest_delete(nearest);
|
2014-06-18 16:14:01 +00:00
|
|
|
|
2014-12-23 10:16:21 +00:00
|
|
|
if (set) codes_fieldset_delete(set);
|
2014-06-18 16:14:01 +00:00
|
|
|
|
2022-02-23 19:01:47 +00:00
|
|
|
for (i = 0; i < nfiles; i++)
|
2022-06-30 09:28:04 +00:00
|
|
|
free((char*)filenames[i]);
|
2022-02-23 19:01:47 +00:00
|
|
|
free(filenames);
|
|
|
|
|
2014-06-18 16:14:01 +00:00
|
|
|
return 0;
|
2013-03-25 12:04:10 +00:00
|
|
|
}
|