mirror of https://github.com/ecmwf/eccodes.git
93 lines
2.0 KiB
C
93 lines
2.0 KiB
C
|
/*
|
||
|
*
|
||
|
* Name: nearest
|
||
|
*
|
||
|
* Description:
|
||
|
* Get the nearest for all the messages in the input grib file.
|
||
|
* No land-sea mask applied yet. Print the nearest values to
|
||
|
* stdout with high precision.
|
||
|
*
|
||
|
* Author: Cristian D Codorean
|
||
|
*/
|
||
|
|
||
|
#include <stdio.h>
|
||
|
#include <stdlib.h>
|
||
|
|
||
|
#include "grib_api.h"
|
||
|
|
||
|
void usage(char* name) {
|
||
|
printf("Usage is: %s lat lon input1 [input2 ...]\n",name);
|
||
|
}
|
||
|
|
||
|
int main(int argc, char** argv) {
|
||
|
|
||
|
grib_handle* h = NULL;
|
||
|
FILE* file_handle = NULL;
|
||
|
int err = 0;
|
||
|
int i = 0;
|
||
|
int nfiles = 0;
|
||
|
int shift = 3;
|
||
|
|
||
|
/* results */
|
||
|
double outlat=0;
|
||
|
double outlon=0;
|
||
|
double value=0;
|
||
|
double distance=0;
|
||
|
int index=0;
|
||
|
size_t size=1;
|
||
|
|
||
|
/* program inputs */
|
||
|
double lat =0,lon = 0;
|
||
|
char** file_names = NULL;
|
||
|
|
||
|
/* just some input validation */
|
||
|
if (argc < 4) {
|
||
|
usage(argv[0]);
|
||
|
exit(EXIT_FAILURE);
|
||
|
}
|
||
|
|
||
|
lat = atof(argv[1]);
|
||
|
lon = atof(argv[2]);
|
||
|
nfiles = argc - shift;
|
||
|
|
||
|
file_names = (char**)malloc(nfiles*sizeof(char*));
|
||
|
for (i = 0; i < nfiles; i++) {
|
||
|
file_names[i] = strdup(argv[i+shift]);
|
||
|
}
|
||
|
|
||
|
|
||
|
|
||
|
for (i = 0; i < nfiles; i++) {
|
||
|
|
||
|
/* open the input file */
|
||
|
file_handle = fopen(file_names[i],"r");
|
||
|
if (!file_handle) {
|
||
|
printf("Could not open file %s\n",file_names[i]);
|
||
|
exit(EXIT_FAILURE);
|
||
|
}
|
||
|
|
||
|
/* loop over all messages */
|
||
|
while (h = grib_handle_new_from_file(0,file_handle,&err)) {
|
||
|
|
||
|
if (err != GRIB_SUCCESS) GRIB_CHECK(err,0);
|
||
|
|
||
|
GRIB_CHECK(grib_nearest_find_multiple(h,0,&lat,&lon,1,&outlat,&outlon,&value,&distance,&index),0);
|
||
|
|
||
|
/*printf("outlat: %lf outlon: %lf value: %.10lf distance: %lf index: %d\n",
|
||
|
outlat, outlon, value, distance, index);*/
|
||
|
|
||
|
printf("%.10lf\n",value);
|
||
|
|
||
|
GRIB_CHECK(grib_handle_delete(h),0);
|
||
|
|
||
|
}
|
||
|
|
||
|
fclose(file_handle);
|
||
|
}
|
||
|
|
||
|
for (i = 0; i < nfiles; i++)
|
||
|
free(file_names[i]);
|
||
|
|
||
|
return 0;
|
||
|
}
|