eccodes/tools/grib_nearest_land.c

153 lines
3.9 KiB
C
Raw Normal View History

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.
*/
/*
* C Implementation: points
*
*/
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include "grib_api_internal.h"
2020-01-22 13:10:59 +00:00
static void usage(char* prog)
{
printf("Usage: %s latlon_file grib_orography grib_file grib_file ...\n", prog);
exit(1);
2013-03-25 12:04:10 +00:00
}
2020-01-22 13:10:59 +00:00
int main(int argc, char** argv)
{
FILE* fin = 0;
int ret = 0;
char* fname = 0;
float lat, lon;
double *vlat, *vlon;
2022-06-30 15:52:04 +00:00
long npoints = 0, i = 0, n = 0;
2020-01-22 13:10:59 +00:00
grib_handle* h;
double *outlats, *outlons, *values, *lsm_values, *distances;
size_t* indexes;
if (argc < 2)
usage(argv[0]);
fname = argv[1];
fin = fopen(fname, "r");
if (!fin) {
perror(fname);
exit(1);
2013-03-25 12:04:10 +00:00
}
2020-01-22 13:10:59 +00:00
npoints = 0;
while (fscanf(fin, "%g %g", &lat, &lon) != EOF)
npoints++;
fclose(fin);
2013-03-25 12:04:10 +00:00
2020-01-22 13:10:59 +00:00
vlat = (double*)malloc(npoints * sizeof(double));
if (!vlat) {
2022-06-30 15:52:04 +00:00
printf("unable to allocate %lu bytes\n", npoints * sizeof(double));
2020-01-22 13:10:59 +00:00
exit(1);
}
vlon = (double*)malloc(npoints * sizeof(double));
if (!vlon) {
2022-06-30 15:52:04 +00:00
printf("unable to allocate %lu bytes\n", npoints * sizeof(double));
2020-01-22 13:10:59 +00:00
exit(1);
}
outlats = (double*)malloc(npoints * sizeof(double));
if (!outlats) {
2022-06-30 15:52:04 +00:00
printf("unable to allocate %lu bytes\n", npoints * sizeof(double));
2020-01-22 13:10:59 +00:00
exit(1);
}
outlons = (double*)malloc(npoints * sizeof(double));
if (!outlons) {
2022-06-30 15:52:04 +00:00
printf("unable to allocate %lu bytes\n", npoints * sizeof(double));
2020-01-22 13:10:59 +00:00
exit(1);
}
values = (double*)malloc(npoints * sizeof(double));
if (!values) {
2022-06-30 15:52:04 +00:00
printf("unable to allocate %lu bytes\n", npoints * sizeof(double));
2020-01-22 13:10:59 +00:00
exit(1);
}
lsm_values = (double*)malloc(npoints * sizeof(double));
if (!lsm_values) {
2022-06-30 15:52:04 +00:00
printf("unable to allocate %lu bytes\n", npoints * sizeof(double));
2020-01-22 13:10:59 +00:00
exit(1);
}
distances = (double*)malloc(npoints * sizeof(double));
if (!distances) {
2022-06-30 15:52:04 +00:00
printf("unable to allocate %lu bytes\n", npoints * sizeof(double));
2020-01-22 13:10:59 +00:00
exit(1);
}
indexes = (size_t*)malloc(npoints * sizeof(double));
if (!indexes) {
2022-06-30 15:52:04 +00:00
printf("unable to allocate %lu bytes\n", npoints * sizeof(double));
2020-01-22 13:10:59 +00:00
exit(1);
}
2013-03-25 12:04:10 +00:00
2020-01-22 13:10:59 +00:00
fname = argv[1];
fin = fopen(fname, "r");
if (!fin) {
perror(fname);
exit(1);
}
i = 0;
while (fscanf(fin, "%g %g", &lat, &lon) != EOF) {
vlat[i] = lat;
vlon[i] = lon > 0 ? lon : lon + 360;
i++;
}
2013-03-25 12:04:10 +00:00
fclose(fin);
2020-01-22 13:10:59 +00:00
fname = argv[2];
fin = fopen(fname, "r");
if (!fin) {
perror(fname);
exit(1);
}
h = grib_handle_new_from_file(0, fin, &ret);
if (!h || ret != GRIB_SUCCESS) {
printf(" unable to create handle\n");
exit(1);
}
grib_nearest_find_multiple(h, 1, vlat, vlon, npoints,
outlats, outlons, lsm_values, distances, indexes);
grib_handle_delete(h);
fclose(fin);
for (n = 3; n <= argc - 1; n++) {
fname = argv[n];
fin = fopen(fname, "r");
if (!fin) {
perror(fname);
exit(1);
}
while ((h = grib_handle_new_from_file(0, fin, &ret)) != NULL) {
grib_get_double_elements(h, "values", indexes, npoints, values);
grib_handle_delete(h);
for (i = 0; i < npoints; i++)
printf("%g %g %g %g %g %g\n",
vlat[i], vlon[i],
outlats[i], outlons[i],
lsm_values[i], values[i]);
}
fclose(fin);
}
2013-03-25 12:04:10 +00:00
2020-01-22 13:10:59 +00:00
return ret;
2013-03-25 12:04:10 +00:00
}