mirror of https://github.com/ecmwf/eccodes.git
Merge branch 'develop' into bugfix/Tigge_S2S_Uerra__marsKeys
This commit is contained in:
commit
586002e473
|
@ -1,2 +1,3 @@
|
|||
SET(ENABLE_EXTRA_TESTS ON CACHE BOOL "Enable extra tests")
|
||||
SET(ENABLE_ECCODES_THREADS ON CACHE BOOL "Enable POSIX threads")
|
||||
SET(ENABLE_MEMFS ON CACHE BOOL "Enable MEMFS")
|
||||
|
|
|
@ -1,2 +1,2 @@
|
|||
# All python tests fail due to error loading the SWIG generated extension module
|
||||
SET( ENABLE_PYTHON OFF CACHE BOOL "Disable Python")
|
||||
SET( ENABLE_PYTHON2 OFF CACHE BOOL "Disable Python")
|
||||
|
|
|
@ -5,3 +5,5 @@
|
|||
|
||||
# All python tests fails due to error loading the shared python lib: undefined symbol: __tsan_init
|
||||
#SET( ENABLE_PYTHON OFF CACHE BOOL "Disable Python")
|
||||
|
||||
SET(ENABLE_MEMFS ON CACHE BOOL "Enable MEMFS")
|
||||
|
|
12
data/ls.log
12
data/ls.log
|
@ -75,17 +75,17 @@ index=1290
|
|||
index=1171
|
||||
index=1170
|
||||
reduced_gaussian_sub_area.grib1
|
||||
#3
|
||||
index=19985
|
||||
index=19984
|
||||
#1
|
||||
index=19665
|
||||
index=19985
|
||||
index=19664
|
||||
index=19984
|
||||
reduced_gaussian_sub_area.grib2
|
||||
#3
|
||||
index=19985
|
||||
index=19984
|
||||
#1
|
||||
index=19665
|
||||
index=19985
|
||||
index=19664
|
||||
index=19984
|
||||
reduced_gaussian_surface.grib1
|
||||
#4
|
||||
index=1291
|
||||
|
|
|
@ -2,10 +2,10 @@
|
|||
set -eu
|
||||
|
||||
# Usage:
|
||||
# create_legacy_def.sh $paramId
|
||||
# create_legacy_def.sh $paramId $paramId...
|
||||
#
|
||||
# This script will insert the local ECMWF GRIB2 representation
|
||||
# for that paramId into the files:
|
||||
# for each paramId into the files:
|
||||
# definitions/grib2/localConcepts/ecmf/paramId.legacy.def
|
||||
# definitions/grib2/localConcepts/ecmf/shortName.legacy.def
|
||||
# etc
|
||||
|
@ -22,7 +22,13 @@ set -eu
|
|||
# The parameterNumber = $paramId - parameterCategory*1000
|
||||
#
|
||||
|
||||
pid=$1
|
||||
if [ $# -eq 0 ]; then
|
||||
echo "Usage: $0 pid1 pid2 ..." 2>&1
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# Input list of paramId values
|
||||
pids="$@"
|
||||
|
||||
sample2=samples/GRIB2.tmpl
|
||||
temp=$TMPDIR/temp.create_legacy_def.grib
|
||||
|
@ -49,23 +55,38 @@ output_def()
|
|||
fi
|
||||
}
|
||||
|
||||
grib_set -s paramId=$pid $sample2 $temp
|
||||
name=$(grib_get -p name $temp)
|
||||
shortName=$(grib_get -p shortName $temp)
|
||||
units=$(grib_get -p units $temp)
|
||||
cfName=$(grib_get -p cfName $temp)
|
||||
cfVarName=$(grib_get -p cfVarName $temp)
|
||||
count=0
|
||||
for pid in $pids; do
|
||||
echo "Doing $pid..."
|
||||
set +e
|
||||
grib_set -s paramId=$pid $sample2 $temp 2>/dev/null
|
||||
status=$?
|
||||
set -e
|
||||
if [ $status -ne 0 ]; then
|
||||
grib_set -s stepType=accum,paramId=$pid $sample2 $temp
|
||||
fi
|
||||
name=$(grib_get -p name $temp)
|
||||
shortName=$(grib_get -p shortName $temp)
|
||||
units=$(grib_get -p units $temp)
|
||||
cfName=$(grib_get -p cfName $temp)
|
||||
cfVarName=$(grib_get -p cfVarName $temp)
|
||||
count=$((count+1))
|
||||
|
||||
dis=192
|
||||
cat=$((pid/1000))
|
||||
num=$((pid - cat*1000))
|
||||
dis=192
|
||||
cat=$((pid/1000))
|
||||
num=$((pid - cat*1000))
|
||||
|
||||
output_def "$name" "$pid" $dis $cat $num >> $defs/paramId.legacy.def
|
||||
output_def "$name" "$name" $dis $cat $num >> $defs/name.legacy.def
|
||||
output_def "$name" "$shortName" $dis $cat $num >> $defs/shortName.legacy.def
|
||||
output_def "$name" "$units" $dis $cat $num >> $defs/units.legacy.def
|
||||
output_def "$name" "$cfVarName" $dis $cat $num >> $defs/cfVarName.legacy.def
|
||||
output_def "$name" "$cfName" $dis $cat $num >> $defs/cfName.legacy.def
|
||||
output_def "$name" "$pid" $dis $cat $num >> $defs/paramId.legacy.def
|
||||
output_def "$name" "$name" $dis $cat $num >> $defs/name.legacy.def
|
||||
output_def "$name" "$shortName" $dis $cat $num >> $defs/shortName.legacy.def
|
||||
output_def "$name" "$units" $dis $cat $num >> $defs/units.legacy.def
|
||||
output_def "$name" "$cfVarName" $dis $cat $num >> $defs/cfVarName.legacy.def
|
||||
output_def "$name" "$cfName" $dis $cat $num >> $defs/cfName.legacy.def
|
||||
|
||||
echo "Files updated. Check directory $defs"
|
||||
done
|
||||
|
||||
echo "Number of legacy parameters added: $count"
|
||||
if [ $count -gt 0 ]; then
|
||||
echo "Files updated. Check directory $defs"
|
||||
fi
|
||||
rm -f $temp
|
||||
|
|
|
@ -93,6 +93,8 @@ concept stepType {
|
|||
"ratio" = {selectStepTemplateInterval=1; stepTypeInternal="ratio";}
|
||||
"stdanom" = {selectStepTemplateInterval=1; stepTypeInternal="stdanom";}
|
||||
"sum" = {selectStepTemplateInterval=1; stepTypeInternal="sum";}
|
||||
"severity" = {selectStepTemplateInterval=1; stepTypeInternal="severity";}
|
||||
"mode" = {selectStepTemplateInterval=1; stepTypeInternal="mode";}
|
||||
}
|
||||
|
||||
# 0=atmospheric chemical constituents
|
||||
|
|
|
@ -68,6 +68,8 @@ if (numberOfTimeRange == 1 || numberOfTimeRange == 2) {
|
|||
"ratio" = {typeOfStatisticalProcessing=9;}
|
||||
"stdanom" = {typeOfStatisticalProcessing=10;}
|
||||
"sum" = {typeOfStatisticalProcessing=11;}
|
||||
"severity" = {typeOfStatisticalProcessing=100;}
|
||||
"mode" = {typeOfStatisticalProcessing=101;}
|
||||
}
|
||||
meta startStep step_in_units(forecastTime,indicatorOfUnitOfTimeRange,stepUnits,
|
||||
indicatorOfUnitForTimeRange,lengthOfTimeRange) : no_copy;
|
||||
|
|
2
memfs.py
2
memfs.py
|
@ -66,7 +66,7 @@ print("MEMFS: Starting")
|
|||
|
||||
# Exclude experimental features e.g. GRIB3 and TAF
|
||||
# The BUFR codetables is not used in the engine
|
||||
EXCLUDED = ["grib3", "codetables", "taf", "stations", "grib1_mlgrib2_ieee32"]
|
||||
EXCLUDED = ["grib3", "codetables", "taf", "metar", "stations", "grib1_mlgrib2_ieee32"]
|
||||
|
||||
EXCLUDE = {
|
||||
None: [],
|
||||
|
|
|
@ -224,7 +224,7 @@ static int unpack_double(grib_accessor* a, double* val, size_t* len)
|
|||
size_t n_vals = 0;
|
||||
size_t size = 0;
|
||||
unsigned char* decoded = NULL;
|
||||
unsigned char* p = NULL;
|
||||
/*unsigned char* p = NULL;*/
|
||||
long pos = 0;
|
||||
long nn = 0;
|
||||
|
||||
|
@ -310,11 +310,14 @@ static int unpack_double(grib_accessor* a, double* val, size_t* len)
|
|||
|
||||
/* printf("bscale=%g dscale=%g reference_value=%g\n",bscale,dscale,reference_value); */
|
||||
pos = 0;
|
||||
#if 0
|
||||
p = decoded;
|
||||
for (i = 0; i < n_vals; i++) {
|
||||
val[i] = (double)(((grib_decode_unsigned_long(p, &pos, bits8) * bscale) + reference_value) * dscale);
|
||||
}
|
||||
/*-------------------------------------------*/
|
||||
#endif
|
||||
/* ECC-1427: Performance improvement */
|
||||
grib_decode_double_array(decoded, &pos, bits8 , reference_value, bscale, dscale, n_vals, val);
|
||||
*len = n_vals;
|
||||
|
||||
cleanup:
|
||||
|
|
|
@ -342,10 +342,7 @@ int grib_nearest_find_generic(
|
|||
double lat1 = 0, lat2 = 0; /* inlat will be between these */
|
||||
const double LAT_DELTA = 10.0; /* in degrees */
|
||||
|
||||
if (grib_is_missing(h, Ni_keyname, &ret)) {
|
||||
grib_context_log(h->context, GRIB_LOG_DEBUG, "Key '%s' is missing", Ni_keyname);
|
||||
return ret ? ret : GRIB_GEOCALCULUS_PROBLEM;
|
||||
}
|
||||
/* Note: If this is being called for a REDUCED grid, its Ni will be missing */
|
||||
|
||||
if (grib_is_missing(h, Nj_keyname, &ret)) {
|
||||
grib_context_log(h->context, GRIB_LOG_DEBUG, "Key '%s' is missing", Nj_keyname);
|
||||
|
|
|
@ -130,17 +130,60 @@ static int init(grib_nearest* nearest, grib_handle* h, grib_arguments* args)
|
|||
|
||||
typedef void (*get_reduced_row_proc)(long pl, double lon_first, double lon_last, long* npoints, long* ilon_first, long* ilon_last);
|
||||
|
||||
static int find_global(grib_nearest* nearest, grib_handle* h,
|
||||
double inlat, double inlon, unsigned long flags,
|
||||
double* outlats, double* outlons, double* values,
|
||||
double* distances, int* indexes, size_t* len);
|
||||
|
||||
static int is_legacy(grib_handle* h)
|
||||
{
|
||||
long is_legacy = 0;
|
||||
return (grib_get_long(h, "legacyGaussSubarea", &is_legacy) == GRIB_SUCCESS && is_legacy == 1);
|
||||
}
|
||||
|
||||
/* Old implementation in src/deprecated/grib_nearest_class_reduced.old */
|
||||
|
||||
static int find(grib_nearest* nearest, grib_handle* h,
|
||||
double inlat, double inlon, unsigned long flags,
|
||||
double* outlats, double* outlons, double* values,
|
||||
double* distances, int* indexes, size_t* len)
|
||||
{
|
||||
int err = 0;
|
||||
grib_nearest_reduced* self = (grib_nearest_reduced*)nearest;
|
||||
|
||||
if (self->global) {
|
||||
err = find_global(nearest, h,
|
||||
inlat, inlon, flags,
|
||||
outlats, outlons, values,
|
||||
distances, indexes, len);
|
||||
}
|
||||
else
|
||||
{
|
||||
/* ECC-762, ECC-1432: Use brute force generic algorithm
|
||||
* for reduced grid subareas. Review in the future
|
||||
*/
|
||||
int lons_count = 0; /*dummy*/
|
||||
|
||||
err = grib_nearest_find_generic(
|
||||
nearest, h, inlat, inlon, flags,
|
||||
self->values_key,
|
||||
"Ni",
|
||||
self->Nj,
|
||||
&(self->lats),
|
||||
&(self->lats_count),
|
||||
&(self->lons),
|
||||
&(lons_count),
|
||||
&(self->distances),
|
||||
outlats, outlons,
|
||||
values, distances, indexes, len);
|
||||
}
|
||||
return err;
|
||||
}
|
||||
|
||||
/* Old implementation in src/deprecated/grib_nearest_class_reduced.old */
|
||||
static int find_global(grib_nearest* nearest, grib_handle* h,
|
||||
double inlat, double inlon, unsigned long flags,
|
||||
double* outlats, double* outlons, double* values,
|
||||
double* distances, int* indexes, size_t* len)
|
||||
{
|
||||
grib_nearest_reduced* self = (grib_nearest_reduced*)nearest;
|
||||
int ret = 0, kk = 0, ii = 0, jj = 0;
|
||||
|
|
|
@ -1477,8 +1477,17 @@ grib_handle* grib_util_set_spec2(grib_handle* h,
|
|||
switch (packing_spec->accuracy) {
|
||||
case GRIB_UTIL_ACCURACY_SAME_BITS_PER_VALUES_AS_INPUT: {
|
||||
long bitsPerValue = 0;
|
||||
if ((packing_spec->packing_type == GRIB_UTIL_PACKING_TYPE_GRID_SIMPLE ||
|
||||
packing_spec->packing_type == GRIB_UTIL_PACKING_TYPE_CCSDS) &&
|
||||
strcmp(input_packing_type, "grid_ieee")==0)
|
||||
{
|
||||
SET_LONG_VALUE("bitsPerValue", 32);
|
||||
}
|
||||
else
|
||||
{
|
||||
Assert(grib_get_long(h, "bitsPerValue", &bitsPerValue) == 0);
|
||||
SET_LONG_VALUE("bitsPerValue", bitsPerValue);
|
||||
}
|
||||
} break;
|
||||
|
||||
case GRIB_UTIL_ACCURACY_USE_PROVIDED_BITS_PER_VALUES:
|
||||
|
|
|
@ -62,7 +62,8 @@ endforeach()
|
|||
if( HAVE_BUILD_TOOLS )
|
||||
|
||||
# These tests do not require any data downloads
|
||||
list(APPEND tests_no_data_reqd
|
||||
# and are generally quick
|
||||
list(APPEND tests_basic
|
||||
unit_tests
|
||||
julian
|
||||
grib_dump_samples
|
||||
|
@ -112,12 +113,9 @@ if( HAVE_BUILD_TOOLS )
|
|||
bufr_ecc-359
|
||||
bufr_ecc-517
|
||||
bufr_rdbSubTypes
|
||||
bufr_templates
|
||||
grib_efas
|
||||
grib_sh_imag
|
||||
grib_sh_spectral_complex
|
||||
pseudo_diag
|
||||
wrap
|
||||
grib_levtype
|
||||
grib_typeOfLevel
|
||||
grib_grid_unstructured
|
||||
|
@ -127,14 +125,16 @@ if( HAVE_BUILD_TOOLS )
|
|||
grib_g1day_of_the_year_date
|
||||
grib_g1fcperiod)
|
||||
|
||||
# These tests do require data downloads
|
||||
list(APPEND tests_data_reqd
|
||||
# These tests require data downloads
|
||||
# and/or take much longer
|
||||
list(APPEND tests_extra
|
||||
grib_data_quality_checks
|
||||
grib_bpv_limit
|
||||
grib_complex
|
||||
grib_double_cmp
|
||||
grib_change_packing
|
||||
grib_grid_space_view
|
||||
bufr_templates
|
||||
bufr_dump_data
|
||||
bufr_dump_descriptors
|
||||
bufr_dump_subset
|
||||
|
@ -201,6 +201,8 @@ if( HAVE_BUILD_TOOLS )
|
|||
gts_ls
|
||||
gts_count
|
||||
gts_compare
|
||||
wrap
|
||||
pseudo_diag
|
||||
metar_ls
|
||||
metar_get
|
||||
metar_dump
|
||||
|
@ -265,21 +267,21 @@ if( HAVE_BUILD_TOOLS )
|
|||
grib_mars_keys)
|
||||
|
||||
if( HAVE_FORTRAN AND ENABLE_EXTRA_TESTS )
|
||||
list(APPEND tests_data_reqd bufr_dump_encode_fortran)
|
||||
list(APPEND tests_data_reqd bufr_dump_decode_fortran)
|
||||
list(APPEND tests_extra bufr_dump_encode_fortran)
|
||||
list(APPEND tests_extra bufr_dump_decode_fortran)
|
||||
endif()
|
||||
if( ENABLE_EXTRA_TESTS )
|
||||
list(APPEND tests_data_reqd grib_util_set_spec)
|
||||
list(APPEND tests_data_reqd grib_padding)
|
||||
list(APPEND tests_data_reqd grib_tigge_conversions1)
|
||||
list(APPEND tests_data_reqd grib_tigge_conversions2)
|
||||
list(APPEND tests_data_reqd bufr_dump_encode_C)
|
||||
list(APPEND tests_data_reqd bufr_dump_decode_C)
|
||||
list(APPEND tests_no_data_reqd list_codetable_flagtable_keys)
|
||||
list(APPEND tests_extra grib_util_set_spec)
|
||||
list(APPEND tests_extra grib_padding)
|
||||
list(APPEND tests_extra grib_tigge_conversions1)
|
||||
list(APPEND tests_extra grib_tigge_conversions2)
|
||||
list(APPEND tests_extra bufr_dump_encode_C)
|
||||
list(APPEND tests_extra bufr_dump_decode_C)
|
||||
list(APPEND tests_extra list_codetable_flagtable_keys)
|
||||
endif()
|
||||
|
||||
# These tests do not require any data downloads
|
||||
foreach( test ${tests_no_data_reqd} )
|
||||
foreach( test ${tests_basic} )
|
||||
ecbuild_add_test( TARGET eccodes_t_${test}
|
||||
TYPE SCRIPT
|
||||
LABELS "sanity"
|
||||
|
@ -294,7 +296,7 @@ if( HAVE_BUILD_TOOLS )
|
|||
# Note: making the test dependent on the grib files (with DEPENDS)
|
||||
# means they will be downloaded at "make" time
|
||||
# rather than when you do "ctest". Use TEST_DEPENDS instead
|
||||
foreach( test ${tests_data_reqd} )
|
||||
foreach( test ${tests_extra} )
|
||||
ecbuild_add_test( TARGET eccodes_t_${test}
|
||||
TYPE SCRIPT
|
||||
CONDITION ENABLE_EXTRA_TESTS
|
||||
|
|
|
@ -13,7 +13,7 @@
|
|||
cd ${data_dir}/bufr
|
||||
|
||||
# Define a common label for all the tmp files
|
||||
label="bufr_change_edition"
|
||||
label="bufr_change_edition_test"
|
||||
|
||||
fBufrTmp=${label}".bufr.tmp"
|
||||
|
||||
|
|
|
@ -10,7 +10,7 @@
|
|||
|
||||
. ./include.ctest.sh
|
||||
|
||||
label="bufr_indexing"
|
||||
label="bufr_indexing_test"
|
||||
tempIndex=temp.$label.$$.idx
|
||||
tempOut=temp.$label.$$.out
|
||||
tempRef=temp.$label.$$.ref
|
||||
|
|
|
@ -11,7 +11,7 @@
|
|||
. ./include.ctest.sh
|
||||
pwd
|
||||
# Define a common label for all the tmp files
|
||||
label="codes_split_file"
|
||||
label="codes_split_file_test"
|
||||
temp=$label.temp.grib
|
||||
|
||||
# Do all the work in a temporary directory
|
||||
|
|
|
@ -12,7 +12,7 @@
|
|||
|
||||
REDIRECT=/dev/null
|
||||
|
||||
label="grib1to3"
|
||||
label="grib1to3_test"
|
||||
temp=temp.$label.grib3
|
||||
sample_g1=$ECCODES_SAMPLES_PATH/GRIB1.tmpl
|
||||
${tools_dir}/grib_set -s editionNumber=3 $sample_g1 $temp
|
||||
|
|
|
@ -10,7 +10,7 @@
|
|||
. ./include.ctest.sh
|
||||
set -u
|
||||
|
||||
label="grib2_templates"
|
||||
label="grib2_templates_test"
|
||||
|
||||
temp1=temp1.$label.grib2
|
||||
temp2=temp2.$label.grib2
|
||||
|
|
|
@ -10,7 +10,7 @@
|
|||
. ./include.ctest.sh
|
||||
|
||||
|
||||
label="grib2_version"
|
||||
label="grib2_version_test"
|
||||
if [ ! -d "$ECCODES_DEFINITION_PATH" ]; then
|
||||
echo "Test $0 disabled. No definitions directory"
|
||||
exit 0
|
||||
|
|
|
@ -11,7 +11,7 @@
|
|||
|
||||
REDIRECT=/dev/null
|
||||
|
||||
label="grib2to3"
|
||||
label="grib2to3_test"
|
||||
temp=temp.$label.grib3
|
||||
sample_g2=$ECCODES_SAMPLES_PATH/GRIB2.tmpl
|
||||
${tools_dir}/grib_set -s editionNumber=3 $sample_g2 $temp
|
||||
|
|
|
@ -11,7 +11,7 @@
|
|||
|
||||
REDIRECT=/dev/null
|
||||
|
||||
label="grib3_templates"
|
||||
label="grib3_templates_test"
|
||||
temp1=temp1.$label.grib3
|
||||
temp2=temp2.$label.grib3
|
||||
|
||||
|
|
|
@ -10,7 +10,7 @@
|
|||
|
||||
. ./include.ctest.sh
|
||||
|
||||
label="grib_change_scanning"
|
||||
label="grib_change_scanning_test"
|
||||
|
||||
editions="1 2"
|
||||
gridTypes="regular_ll rotated_ll"
|
||||
|
|
|
@ -9,7 +9,7 @@
|
|||
|
||||
. ./include.ctest.sh
|
||||
|
||||
label="grib_check_gaussian_grids"
|
||||
label="grib_check_gaussian_grids_test"
|
||||
temp=temp.$label.grib
|
||||
|
||||
|
||||
|
|
|
@ -10,7 +10,7 @@
|
|||
|
||||
. ./include.ctest.sh
|
||||
|
||||
label="grib_complex"
|
||||
label="grib_complex_test"
|
||||
temp=${label}".grib.tmp"
|
||||
temp1=${label}".1.tmp"
|
||||
temp2=${label}".2.tmp"
|
||||
|
|
|
@ -13,7 +13,7 @@
|
|||
# ---------------------------------------------------------
|
||||
# Tests for data quality checks
|
||||
# ---------------------------------------------------------
|
||||
label="grib_data_quality"
|
||||
label="grib_data_quality_test"
|
||||
tempOut=temp.1.${label}.out
|
||||
temp2=temp.2.${label}.out
|
||||
tempErr=temp.${label}.err
|
||||
|
|
|
@ -9,7 +9,7 @@
|
|||
#
|
||||
|
||||
. ./include.ctest.sh
|
||||
label="grib_dump_debug"
|
||||
label="grib_dump_debug_test"
|
||||
temp=temp.$label.txt
|
||||
|
||||
REDIRECT=/dev/null
|
||||
|
|
|
@ -10,7 +10,7 @@
|
|||
|
||||
. ./include.ctest.sh
|
||||
|
||||
label="grib_dump_json"
|
||||
label="grib_dump_json_test"
|
||||
temp=${label}".temp.json"
|
||||
|
||||
REDIRECT=/dev/null
|
||||
|
|
|
@ -10,7 +10,7 @@
|
|||
|
||||
. ./include.ctest.sh
|
||||
|
||||
label="grib_efas"
|
||||
label="grib_efas_test"
|
||||
sample=temp.sample.$label.grib
|
||||
temp1=temp1.$label.grib
|
||||
temp2=temp2.$label.grib
|
||||
|
|
|
@ -10,7 +10,7 @@
|
|||
|
||||
. ./include.ctest.sh
|
||||
|
||||
label="grib_g1fcperiod"
|
||||
label="grib_g1fcperiod_test"
|
||||
sample_g1=$ECCODES_SAMPLES_PATH/GRIB1.tmpl
|
||||
temp=temp.$label.grib
|
||||
|
||||
|
|
|
@ -10,7 +10,7 @@
|
|||
|
||||
. ./include.ctest.sh
|
||||
|
||||
label="grib_g1monthlydate"
|
||||
label="grib_g1monthlydate_test"
|
||||
sample_g1=$ECCODES_SAMPLES_PATH/GRIB1.tmpl
|
||||
temp=temp.$label.grib
|
||||
|
||||
|
|
|
@ -10,7 +10,7 @@
|
|||
|
||||
. ./include.ctest.sh
|
||||
|
||||
label="grib_grid_unstructured"
|
||||
label="grib_grid_unstructured_test"
|
||||
|
||||
# Only relevant for GRIB2
|
||||
sample=$ECCODES_SAMPLES_PATH/GRIB2.tmpl
|
||||
|
|
|
@ -10,7 +10,7 @@
|
|||
|
||||
. ./include.ctest.sh
|
||||
|
||||
label="grib_indexing"
|
||||
label="grib_indexing_test"
|
||||
temp=temp.$label.index.out
|
||||
infile=${data_dir}/index.grib
|
||||
|
||||
|
|
|
@ -10,7 +10,7 @@
|
|||
|
||||
. ./include.ctest.sh
|
||||
|
||||
label="grib_lam_bf"
|
||||
label="grib_lam_bf_test"
|
||||
temp=temp.$label.txt
|
||||
|
||||
if [ $ECCODES_ON_WINDOWS -eq 1 ]; then
|
||||
|
|
|
@ -10,7 +10,7 @@
|
|||
|
||||
. ./include.ctest.sh
|
||||
|
||||
label="grib_lam_gp"
|
||||
label="grib_lam_gp_test"
|
||||
temp=temp.$label.txt
|
||||
|
||||
dump_and_check()
|
||||
|
|
|
@ -10,7 +10,7 @@
|
|||
|
||||
. ./include.ctest.sh
|
||||
set -u
|
||||
label="grib_levtype"
|
||||
label="grib_levtype_test"
|
||||
|
||||
if [ ! -d "$ECCODES_DEFINITION_PATH" ]; then
|
||||
echo "Test $0 disabled. No definitions directory"
|
||||
|
|
|
@ -10,7 +10,7 @@
|
|||
|
||||
. ./include.ctest.sh
|
||||
|
||||
label="grib_mars_keys"
|
||||
label="grib_mars_keys_test"
|
||||
tempOut=temp.${label}.out
|
||||
tempGrib=temp.${label}.grib
|
||||
tempRef=temp.${label}.ref
|
||||
|
|
|
@ -119,6 +119,22 @@ ${tools_dir}/grib_ls -l 0,0,1 $tempGrib > $temp
|
|||
grep -q "Grid Point chosen #2 index=480 " $temp
|
||||
|
||||
|
||||
# Subarea: Reduced Gaussian grid
|
||||
# ------------------------------
|
||||
input_grb=${data_dir}/reduced_gaussian_sub_area.grib1
|
||||
${tools_dir}/grib_get -F%3.6g -l 89.656,220,1 $input_grb > $temp
|
||||
grep -q "274.038" $temp
|
||||
${tools_dir}/grib_ls -l 89.656,220,1 $input_grb > $temp
|
||||
grep -q "Grid Point chosen #1 index=0 " $temp
|
||||
|
||||
${tools_dir}/grib_ls -l 0.225,399.6,1 $input_grb > $temp
|
||||
grep -q "Grid Point chosen #1 index=53563 " $temp
|
||||
|
||||
${tools_dir}/grib_get -F%3.6g -l 11.91,366.3,1 $input_grb > $temp
|
||||
grep -q "299.632" $temp
|
||||
${tools_dir}/grib_ls -l 11.91,366.3,1 $input_grb > $temp
|
||||
grep -q "Grid Point chosen #1 index=43089 " $temp
|
||||
|
||||
|
||||
# Clean up
|
||||
rm -f $temp $tempRef $tempGrib
|
||||
|
|
|
@ -11,7 +11,7 @@
|
|||
. ./include.ctest.sh
|
||||
|
||||
REDIRECT=/dev/null
|
||||
label="grib_packing_order"
|
||||
label="grib_packing_order_test"
|
||||
temp=${label}".grib.tmp"
|
||||
temp_simple1=${label}".simple1.tmp"
|
||||
temp_simple2=${label}".simple2.tmp"
|
||||
|
|
|
@ -10,7 +10,7 @@
|
|||
|
||||
. ./include.ctest.sh
|
||||
|
||||
label="grib_png"
|
||||
label="grib_png_test"
|
||||
temp=${label}".grib.tmp"
|
||||
temp1=${label}".1.tmp"
|
||||
temp2=${label}".2.tmp"
|
||||
|
|
|
@ -62,6 +62,7 @@ diff ${data_dir}/step_grib1.log ${templog}
|
|||
rm -f ${templog}
|
||||
|
||||
# GRIB-180
|
||||
# ------------
|
||||
# Set PDT 4.8 where you can find the EndOfOverallTimeInterval keys
|
||||
grib2File=${data_dir}/reduced_latlon_surface_constant.grib2
|
||||
${tools_dir}/grib_set -sproductDefinitionTemplateNumber=8 $grib2File ${grib2File}.p8tmp
|
||||
|
@ -81,6 +82,7 @@ hourEnd=$1; dayEnd=$2
|
|||
|
||||
|
||||
# ECC-134 case-sensitivity
|
||||
# --------------------------
|
||||
grib1_sample=$ECCODES_SAMPLES_PATH/GRIB1.tmpl
|
||||
grib2_sample=$ECCODES_SAMPLES_PATH/GRIB2.tmpl
|
||||
temp=temp.step.$$.grib
|
||||
|
@ -93,6 +95,7 @@ unit=`${tools_dir}/grib_get -p indicatorOfUnitOfTimeRange $temp`
|
|||
[ "$unit" = "3" ]
|
||||
|
||||
# m is for Minute (code 0)
|
||||
# -------------------------
|
||||
${tools_dir}/grib_set -s indicatorOfUnitOfTimeRange=m $grib1_sample $temp
|
||||
unit=`${tools_dir}/grib_get -p unitOfTimeRange $temp`
|
||||
[ "$unit" = "0" ]
|
||||
|
@ -101,9 +104,18 @@ unit=`${tools_dir}/grib_get -p indicatorOfUnitOfTimeRange $temp`
|
|||
[ "$unit" = "0" ]
|
||||
|
||||
# ECC-457
|
||||
# ---------
|
||||
input=${data_dir}/tp_ecmwf.grib
|
||||
stepRange=`${tools_dir}/grib_get -w count=1 -p stepRange,startStep,endStep,stepType $input`
|
||||
[ "$stepRange" = "12 12 12 instant" ]
|
||||
|
||||
# ECC-1430: stepType: 'severity' and 'mode'
|
||||
# -----------------------------------------
|
||||
${tools_dir}/grib_set -s stepType=severity,paramId=260318 $grib2_sample $temp
|
||||
grib_check_key_equals $temp productDefinitionTemplateNumber,typeOfStatisticalProcessing '8 100'
|
||||
${tools_dir}/grib_set -s stepType=mode,paramId=260320 $grib2_sample $temp
|
||||
grib_check_key_equals $temp productDefinitionTemplateNumber,typeOfStatisticalProcessing '8 101'
|
||||
|
||||
# Clean up
|
||||
rm -f $temp
|
||||
rm -f $grib2File.p8tmp ${grib2File}.tmp x.grib
|
||||
|
|
|
@ -16,7 +16,7 @@
|
|||
|
||||
REDIRECT=/dev/null
|
||||
|
||||
label="grib_tigge_conv1"
|
||||
label="grib_tigge_conv1_test"
|
||||
dir="${data_dir}/tigge"
|
||||
temp1="temp.${label}.grib1_"
|
||||
temp2="temp.${label}.grib2_"
|
||||
|
|
|
@ -16,7 +16,7 @@
|
|||
|
||||
REDIRECT=/dev/null
|
||||
|
||||
label="grib_tigge_conv2"
|
||||
label="grib_tigge_conv2_test"
|
||||
dir="${data_dir}/tigge"
|
||||
temp1="temp.${label}.grib1_"
|
||||
temp2="temp.${label}.grib2_"
|
||||
|
|
|
@ -144,7 +144,7 @@ static int process_file(const char* filename)
|
|||
}
|
||||
|
||||
if (lon1 != 0) {
|
||||
error(filename, msg_num, "latitudeOfFirstGridPointInDegrees=%f but should be 0\n", lon1);
|
||||
error(filename, msg_num, "longitudeOfFirstGridPointInDegrees=%f but should be 0\n", lon1);
|
||||
}
|
||||
expected_lon2 = 360.0 - 360.0 / (4 * N);
|
||||
|
||||
|
|
|
@ -105,7 +105,7 @@ static grib_options_help grib_options_help_list[] = {
|
|||
{ "T:", "T | B | M | A", "Message type. T->GTS, B->BUFR, M->METAR (Experimental), A->Any (Experimental).\n\t\t\t\tThe input file is interpreted according to the message type.\n" },
|
||||
{ "V", 0, "Version.\n" },
|
||||
{ "W:", "width", "\n\t\tMinimum width of each column in output. Default is 10.\n" },
|
||||
{ "X:", "offset", "\n\t\tInput file offset in bytes. Processing of the input file will start from \"offset\".\n" },
|
||||
{ "X:", "offset", "\n\t\tInput file offset in bytes. Processing of the input file will start from the given offset.\n" },
|
||||
{ "x", 0, "Fast parsing option, only headers are loaded.\n" },
|
||||
{ "k:", "key1,key2,...",
|
||||
"\n\t\tSpecify a list of keys to index on. By default the input files are indexed on the MARS keys."
|
||||
|
|
Loading…
Reference in New Issue