Testing: METAR compare

This commit is contained in:
Shahram Najm 2024-01-03 11:52:23 +00:00
parent 7424b76096
commit e6aafdb7dc
3 changed files with 56 additions and 36 deletions

View File

@ -65,6 +65,18 @@ grep -q "DIFFERENCE == string.*theMessage" $fLog
# The -d option should have created these files # The -d option should have created these files
rm -f error1_1.metar error2_1.metar error1_2.metar error2_2.metar rm -f error1_1.metar error2_1.metar error1_2.metar error2_2.metar
#----------------------------------------------------
# Compare a key of type double
#----------------------------------------------------
temp1=temp.$label.metar.1
temp2=temp.$label.metar.2
${tools_dir}/metar_copy -w count=1 $metar_file $temp1
${tools_dir}/metar_copy -w count=2 $metar_file $temp2
# absolute diff. = 16.53, relative diff. = 0.381315
${tools_dir}/metar_compare -c latitude -R latitude=0.4 $temp1 $temp2
${tools_dir}/metar_compare -c latitude -A 17 $temp1 $temp2
rm -f $temp1 $temp2
#---------------------------------------------------- #----------------------------------------------------
# Test: comparing with and without the -b switch # Test: comparing with and without the -b switch
#---------------------------------------------------- #----------------------------------------------------

View File

@ -383,15 +383,14 @@ int grib_tool_init(grib_runtime_options* options)
} }
} }
{ // Check for 2nd file being a directory. If so, we assume user is comparing to a file
/* Check for 2nd file being a directory. If so, we assume user is comparing to a file */ // with the same name as first file in that directory
/* with the same name as first file in that directory */ grib_tools_file* infile = options->infile; // the 2nd file in comparison
grib_tools_file* infile = options->infile; /* the 2nd file in comparison */
if (infile) { if (infile) {
if (path_is_directory(infile->name)) { if (path_is_directory(infile->name)) {
/* Take the filename of the 1st file and append to dir */ // Take the filename of the 1st file and append to dir
char bufr[2048] = {0,}; char bufr[2048] = {0,};
/* options->infile_extra->name is the 1st file */ // options->infile_extra->name is the 1st file
snprintf(bufr, sizeof(bufr), "%s%c%s", snprintf(bufr, sizeof(bufr), "%s%c%s",
infile->name, infile->name,
get_dir_separator_char(), get_dir_separator_char(),
@ -399,7 +398,6 @@ int grib_tool_init(grib_runtime_options* options)
infile->name = strdup(bufr); infile->name = strdup(bufr);
} }
} }
}
return 0; return 0;
} }

View File

@ -279,15 +279,24 @@ int grib_tool_init(grib_runtime_options* options)
if (grib_options_on("t:")) if (grib_options_on("t:"))
tolerance_factor = atof(grib_options_get_option("t:")); tolerance_factor = atof(grib_options_get_option("t:"));
{ if (grib_options_on("R:")) {
/* Check for 2nd file being a directory. If so, we assume user is comparing to a file */ char* sarg = grib_options_get_option("R:");
/* with the same name as first file in that directory */ options->tolerance_count = MAX_KEYS;
grib_tools_file* infile = options->infile; /* the 2nd file in comparison */ int err = parse_keyval_string(tool_name, sarg, 1, GRIB_TYPE_DOUBLE, options->tolerance, &(options->tolerance_count));
if (err == GRIB_INVALID_ARGUMENT) {
usage();
exit(1);
}
}
// Check for 2nd file being a directory. If so, we assume user is comparing to a file
// with the same name as first file in that directory
grib_tools_file* infile = options->infile; // the 2nd file in comparison
if (infile) { if (infile) {
if (path_is_directory(infile->name)) { if (path_is_directory(infile->name)) {
/* Take the filename of the 1st file and append to dir */ // Take the filename of the 1st file and append to dir
char bufr[2048] = {0,}; char bufr[2048] = {0,};
/* options->infile_extra->name is the 1st file */ // options->infile_extra->name is the 1st file
snprintf(bufr, 2048, "%s%c%s", snprintf(bufr, 2048, "%s%c%s",
infile->name, infile->name,
get_dir_separator_char(), get_dir_separator_char(),
@ -295,7 +304,6 @@ int grib_tool_init(grib_runtime_options* options)
infile->name = strdup(bufr); infile->name = strdup(bufr);
} }
} }
}
return 0; return 0;
} }
@ -693,8 +701,14 @@ static int compare_values(grib_runtime_options* options, grib_handle* h1, grib_h
pv1 = dval1; pv1 = dval1;
pv2 = dval2; pv2 = dval2;
value_tolerance *= tolerance_factor; value_tolerance *= tolerance_factor;
if (verbose) if (verbose) {
printf(" (%d values) tolerance=%g\n", (int)len1, value_tolerance); printf(" (%d values) tolerance=%g \t", (int)len1, value_tolerance);
if (compare_double == &compare_double_absolute)
printf("using compare_double_absolute");
if (compare_double == &compare_double_relative)
printf("using compare_double_relative");
printf("\n");
}
for (i = 0; i < len1; i++) { for (i = 0; i < len1; i++) {
if ((diff = compare_double(pv1++, pv2++, &value_tolerance)) != 0) { if ((diff = compare_double(pv1++, pv2++, &value_tolerance)) != 0) {
countdiff++; countdiff++;
@ -828,7 +842,6 @@ static int compare_all_dump_keys(grib_handle* h1, grib_handle* h2, grib_runtime_
while (grib_keys_iterator_next(iter)) { while (grib_keys_iterator_next(iter)) {
grib_accessor* xa = grib_keys_iterator_get_accessor(iter); grib_accessor* xa = grib_keys_iterator_get_accessor(iter);
name = grib_keys_iterator_get_name(iter); name = grib_keys_iterator_get_name(iter);
/* printf("----- comparing %s\n",name); */
if (blocklisted(name)) if (blocklisted(name))
continue; continue;
@ -864,7 +877,6 @@ static int compare_handles(grib_handle* h1, grib_handle* h2, grib_runtime_option
} }
while (grib_keys_iterator_next(iter)) { while (grib_keys_iterator_next(iter)) {
name = grib_keys_iterator_get_name(iter); name = grib_keys_iterator_get_name(iter);
/*printf("----- comparing %s\n",name);*/
if (blocklisted(name)) if (blocklisted(name))
continue; continue;
@ -886,7 +898,6 @@ static int compare_handles(grib_handle* h1, grib_handle* h2, grib_runtime_option
const void *msg1 = NULL, *msg2 = NULL; const void *msg1 = NULL, *msg2 = NULL;
size_t size1 = 0, size2 = 0; size_t size1 = 0, size2 = 0;
int memcmp_ret = 0; int memcmp_ret = 0;
/* int ii=0; */
GRIB_CHECK_NOLINE(grib_get_message(h1, &msg1, &size1), 0); GRIB_CHECK_NOLINE(grib_get_message(h1, &msg1, &size1), 0);
GRIB_CHECK_NOLINE(grib_get_message(h2, &msg2, &size2), 0); GRIB_CHECK_NOLINE(grib_get_message(h2, &msg2, &size2), 0);
if (size1 == size2 && !(memcmp_ret = memcmp(msg1, msg2, size1))) { if (size1 == size2 && !(memcmp_ret = memcmp(msg1, msg2, size1))) {
@ -905,7 +916,6 @@ static int compare_handles(grib_handle* h1, grib_handle* h2, grib_runtime_option
} }
while (grib_keys_iterator_next(iter)) { while (grib_keys_iterator_next(iter)) {
name = grib_keys_iterator_get_name(iter); name = grib_keys_iterator_get_name(iter);
/*printf("----- comparing %s\n",name);*/
if (blocklisted(name)) if (blocklisted(name))
continue; continue;