Add test to demonstrate that laplam (grib_accessor_class_data_g2bifourier_packing.c) is now broken.

This commit is contained in:
Philippe Marguinaud 2021-02-24 19:00:53 +01:00
parent d5f43831a7
commit e0376b72d9
1 changed files with 31 additions and 15 deletions

View File

@ -672,6 +672,8 @@ typedef struct
{ {
int trunc; /* 77, 88, 99 = truncation type */ int trunc; /* 77, 88, 99 = truncation type */
int subtrunc; /* 77, 88, 99 = subtruncation type */ int subtrunc; /* 77, 88, 99 = subtruncation type */
int subnsmax;
int subnmsmax;
double* values; double* values;
int len; int len;
const char* name; const char* name;
@ -683,11 +685,13 @@ int main(int argc, char* argv[])
size_t len; size_t len;
const char* grids[] = { "lambert_bf", "mercator_bf", "polar_stereographic_bf" }; const char* grids[] = { "lambert_bf", "mercator_bf", "polar_stereographic_bf" };
int igrid, itrunc; int igrid, itrunc;
trunc_t trunc[2]; trunc_t trunc[3];
/* Elliptic truncation with diamond subtruncation */ /* Elliptic truncation with diamond subtruncation */
trunc[0].trunc = 88; trunc[0].trunc = 88;
trunc[0].subtrunc = 99; trunc[0].subtrunc = 99;
trunc[0].subnsmax = NSTRON;
trunc[0].subnmsmax = NSTRON;
trunc[0].len = ILCHAM; trunc[0].len = ILCHAM;
trunc[0].values = (double*)values; trunc[0].values = (double*)values;
trunc[0].name = "ellipse_diamond"; trunc[0].name = "ellipse_diamond";
@ -695,13 +699,25 @@ int main(int argc, char* argv[])
/* Rectangle truncation with rectangle subtruncation */ /* Rectangle truncation with rectangle subtruncation */
trunc[1].trunc = 77; trunc[1].trunc = 77;
trunc[1].subtrunc = 77; trunc[1].subtrunc = 77;
trunc[1].subnsmax = NSTRON;
trunc[2].subnmsmax = NSTRON;
trunc[1].len = 4 * (NSMAX + 1) * (NMSMAX + 1); trunc[1].len = 4 * (NSMAX + 1) * (NMSMAX + 1);
trunc[1].values = (double*)malloc(sizeof(double) * trunc[1].len); trunc[1].values = (double*)malloc(sizeof(double) * trunc[1].len);
trunc[1].name = "rectangle_rectangle"; trunc[1].name = "rectangle_rectangle";
rectfromellipse(trunc[1].values, trunc[0].values, NSMAX, NMSMAX); rectfromellipse(trunc[1].values, trunc[0].values, NSMAX, NMSMAX);
for (itrunc = 0; itrunc < 2; itrunc++) { /* Elliptic truncation with full subtruncation */
trunc[2].trunc = 88;
trunc[2].subtrunc = 88;
trunc[2].subnsmax = NSMAX;
trunc[2].subnmsmax = NMSMAX;
trunc[2].len = ILCHAM;
trunc[2].values = (double*)values;
trunc[2].name = "ellipse_full";
for (itrunc = 0; itrunc < 3; itrunc++) {
for (igrid = 0; igrid < 3; igrid++) { for (igrid = 0; igrid < 3; igrid++) {
GRIB_CHECK(((h = grib_handle_new_from_samples(NULL, "lambert_bf_grib2")) == NULL), 0); GRIB_CHECK(((h = grib_handle_new_from_samples(NULL, "lambert_bf_grib2")) == NULL), 0);
@ -750,8 +766,8 @@ int main(int argc, char* argv[])
len = strlen("bifourier_complex"); len = strlen("bifourier_complex");
GRIB_CHECK(grib_set_string(h, "packingType", "bifourier_complex", &len), 0); GRIB_CHECK(grib_set_string(h, "packingType", "bifourier_complex", &len), 0);
GRIB_CHECK(grib_set_long(h, "biFourierResolutionSubSetParameterN", NSTRON), 0); GRIB_CHECK(grib_set_long(h, "biFourierResolutionSubSetParameterN", trunc[itrunc].subnsmax), 0);
GRIB_CHECK(grib_set_long(h, "biFourierResolutionSubSetParameterM", NSTRON), 0); GRIB_CHECK(grib_set_long(h, "biFourierResolutionSubSetParameterM", trunc[itrunc].subnmsmax), 0);
GRIB_CHECK(grib_set_long(h, "biFourierSubTruncationType", trunc[itrunc].subtrunc), 0); GRIB_CHECK(grib_set_long(h, "biFourierSubTruncationType", trunc[itrunc].subtrunc), 0);
GRIB_CHECK(grib_set_long(h, "biFourierPackingModeForAxes", 1), 0); GRIB_CHECK(grib_set_long(h, "biFourierPackingModeForAxes", 1), 0);
GRIB_CHECK(grib_set_long(h, "unpackedSubsetPrecision", 2), 0); GRIB_CHECK(grib_set_long(h, "unpackedSubsetPrecision", 2), 0);