ECC-1510: Fix the statistics keys: min, max and average

This commit is contained in:
Shahram Najm 2023-02-13 14:18:15 +00:00
parent a1d55b5b5c
commit e85de787ce
2 changed files with 9 additions and 2 deletions

View File

@ -50,6 +50,10 @@ if (bitMapIndicator == 255)
if (dataRepresentationTemplateNumber == 2 || dataRepresentationTemplateNumber == 3) { if (dataRepresentationTemplateNumber == 2 || dataRepresentationTemplateNumber == 3) {
transient missingValuesPresent = (missingValueManagementUsed != 0) : read_only; transient missingValuesPresent = (missingValueManagementUsed != 0) : read_only;
} }
if (dataRepresentationTemplateNumber == 200) {
# This template can have undefined values within its Data Section
transient missingValuesPresent = 1;
}
} }
meta md5Section6 md5(offsetSection6,section6Length); meta md5Section6 md5(offsetSection6,section6Length);

View File

@ -183,6 +183,7 @@ static int unpack_double(grib_accessor* a, double* val, size_t* len)
double level_scale_factor = 0; double level_scale_factor = 0;
double* levels = NULL; double* levels = NULL;
unsigned char* buf = NULL; unsigned char* buf = NULL;
double missingValue = 9999.0;
if ((err = grib_get_long_internal(gh, self->seclen, &seclen)) != GRIB_SUCCESS) if ((err = grib_get_long_internal(gh, self->seclen, &seclen)) != GRIB_SUCCESS)
return err; return err;
@ -196,6 +197,8 @@ static int unpack_double(grib_accessor* a, double* val, size_t* len)
return err; return err;
if ((err = grib_get_long_internal(gh, self->decimal_scale_factor, &decimal_scale_factor)) != GRIB_SUCCESS) if ((err = grib_get_long_internal(gh, self->decimal_scale_factor, &decimal_scale_factor)) != GRIB_SUCCESS)
return err; return err;
if ((err = grib_get_double(gh, "missingValue", &missingValue)) != GRIB_SUCCESS)
return err;
level_values = (long*)grib_context_malloc_clear(a->context, sizeof(long) * number_of_level_values); level_values = (long*)grib_context_malloc_clear(a->context, sizeof(long) * number_of_level_values);
level_values_size = number_of_level_values; level_values_size = number_of_level_values;
@ -206,7 +209,7 @@ static int unpack_double(grib_accessor* a, double* val, size_t* len)
number_of_compressed_values = ((seclen - 5) * 8) / bits_per_value; number_of_compressed_values = ((seclen - 5) * 8) / bits_per_value;
if (number_of_compressed_values == 0 || max_level_value == 0) { if (number_of_compressed_values == 0 || max_level_value == 0) {
for (i = 0; i < number_of_values; i++) { for (i = 0; i < number_of_values; i++) {
val[i] = GRIB_MISSING_DOUBLE; val[i] = missingValue;
} }
return GRIB_SUCCESS; return GRIB_SUCCESS;
} }
@ -220,7 +223,7 @@ static int unpack_double(grib_accessor* a, double* val, size_t* len)
} }
level_scale_factor = grib_power(-decimal_scale_factor, 10.0); level_scale_factor = grib_power(-decimal_scale_factor, 10.0);
levels = (double*)grib_context_malloc_clear(a->context, sizeof(double) * (number_of_level_values + 1)); levels = (double*)grib_context_malloc_clear(a->context, sizeof(double) * (number_of_level_values + 1));
levels[0] = 0; levels[0] = missingValue;
for (i = 0; i < number_of_level_values; i++) { for (i = 0; i < number_of_level_values; i++) {
levels[i + 1] = level_values[i] * level_scale_factor; levels[i + 1] = level_values[i] * level_scale_factor;
} }