2013-03-25 12:04:10 +00:00
|
|
|
#!/bin/sh
|
2020-01-28 14:32:34 +00:00
|
|
|
# (C) Copyright 2005- ECMWF.
|
2013-03-25 12:04:10 +00:00
|
|
|
#
|
|
|
|
# This software is licensed under the terms of the Apache Licence Version 2.0
|
|
|
|
# which can be obtained at http://www.apache.org/licenses/LICENSE-2.0.
|
|
|
|
#
|
|
|
|
# In applying this licence, ECMWF does not waive the privileges and immunities granted to it by
|
|
|
|
# virtue of its status as an intergovernmental organisation nor does it submit to any jurisdiction.
|
|
|
|
#
|
|
|
|
|
|
|
|
. ./include.sh
|
|
|
|
|
|
|
|
workdir=`pwd`
|
|
|
|
REDIRECT=/dev/null
|
|
|
|
|
|
|
|
cd ${data_dir}
|
|
|
|
|
|
|
|
encoding=1
|
|
|
|
simple_no_bitmap=simple.grib
|
|
|
|
simple_bitmap=simple_bitmap.grib
|
2017-04-05 11:49:16 +00:00
|
|
|
test_filter=temp.grib_second_order.filter
|
2013-03-25 12:04:10 +00:00
|
|
|
|
|
|
|
files_no_bitmap="gen_ext.grib \
|
|
|
|
gen_ext_boust.grib \
|
|
|
|
gen_ext_spd_2.grib \
|
|
|
|
gen_ext_spd_3.grib \
|
|
|
|
gen.grib row.grib "
|
|
|
|
|
|
|
|
files_bitmap="constant_width_bitmap.grib \
|
|
|
|
constant_width_boust_bitmap.grib \
|
|
|
|
gen_bitmap.grib \
|
|
|
|
gen_ext_bitmap.grib \
|
|
|
|
gen_ext_boust_bitmap.grib \
|
|
|
|
gen_ext_spd_2_bitmap.grib \
|
|
|
|
gen_ext_spd_2_boust_bitmap.grib \
|
|
|
|
gen_ext_spd_3_boust_bitmap.grib \
|
|
|
|
simple_bitmap.grib"
|
|
|
|
|
|
|
|
no_packing="gen.grib|row.grib|gen_bitmap.grib|constant_width_bitmap.grib|constant_width_boust_bitmap.grib"
|
|
|
|
|
|
|
|
test_data() {
|
2017-04-05 11:49:16 +00:00
|
|
|
${tools_dir}/grib_filter $test_filter $simple > $simple.data
|
2017-03-27 15:23:25 +00:00
|
|
|
|
|
|
|
for f in $files
|
|
|
|
do
|
2017-04-05 11:49:16 +00:00
|
|
|
${tools_dir}/grib_filter $test_filter $f > $f.data
|
2017-03-27 15:23:25 +00:00
|
|
|
diff $simple.data $f.data > /dev/null
|
|
|
|
${tools_dir}/grib_compare -cvalues $f $simple
|
|
|
|
echo $f decoding test passed > $REDIRECT
|
|
|
|
|
|
|
|
exclude=`echo $f | awk " /$no_packing/ {print \"found\";} "`
|
|
|
|
if [ -z "$exclude" ] && [ $encoding != 0 ]
|
|
|
|
then
|
|
|
|
rm -f $f.copied
|
|
|
|
${tools_dir}/grib_copy -r $f $f.copied
|
2017-04-05 11:49:16 +00:00
|
|
|
${tools_dir}/grib_filter $test_filter $f.copied > $f.copied.data
|
2017-03-27 15:23:25 +00:00
|
|
|
diff $simple.data $f.copied.data > /dev/null
|
|
|
|
${tools_dir}/grib_compare -cvalues $f.copied $simple
|
|
|
|
echo $f encoding test passed > $REDIRECT
|
|
|
|
echo > $REDIRECT
|
|
|
|
fi
|
|
|
|
|
|
|
|
done
|
|
|
|
rm -f *.data *.copied
|
2013-03-25 12:04:10 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-04-05 11:49:16 +00:00
|
|
|
cat > $test_filter<<EOF
|
2013-03-25 12:04:10 +00:00
|
|
|
print "[values!1]!";
|
|
|
|
EOF
|
|
|
|
|
|
|
|
simple=$simple_no_bitmap
|
|
|
|
files=$files_no_bitmap
|
|
|
|
test_data
|
|
|
|
|
|
|
|
simple=$simple_bitmap
|
|
|
|
files=$files_bitmap
|
|
|
|
test_data
|
|
|
|
|
|
|
|
# Now make sure grib_dump works on a second-order row-by-row file
|
|
|
|
# See GRIB-147
|
2017-02-03 14:21:24 +00:00
|
|
|
${tools_dir}/grib_dump second_ord_rbr.grib1 > $REDIRECT
|
2013-03-25 12:04:10 +00:00
|
|
|
|
2014-07-25 10:13:00 +00:00
|
|
|
# Test nearest neighbour on second order with a bitmap
|
|
|
|
# GRIB-541
|
|
|
|
sec_ord_bmp=sec_ord_bmp.$$.grib1
|
2013-03-25 12:04:10 +00:00
|
|
|
|
2014-07-25 10:13:00 +00:00
|
|
|
# Convert to second order packing
|
2017-02-03 14:21:24 +00:00
|
|
|
${tools_dir}/grib_set -r -s packingType=grid_second_order gen_bitmap.grib $sec_ord_bmp
|
2014-07-25 10:13:00 +00:00
|
|
|
# Check there are missing values
|
2017-02-03 14:21:24 +00:00
|
|
|
nums=`${tools_dir}/grib_get -p numberOfDataPoints,numberOfCodedValues,numberOfMissing $sec_ord_bmp`
|
2014-07-25 10:13:00 +00:00
|
|
|
[ "$nums" = "5969 4 5965" ]
|
|
|
|
|
2017-02-03 14:21:24 +00:00
|
|
|
res=`${tools_dir}/grib_get -l 33,88.5 $sec_ord_bmp`
|
2014-07-25 10:13:00 +00:00
|
|
|
[ "$res" = "9999 5.51552 9999 9999 " ]
|
|
|
|
|
2017-03-27 15:23:25 +00:00
|
|
|
res=`${tools_dir}/grib_get -l 28.5,90 $sec_ord_bmp`
|
2014-07-25 10:13:00 +00:00
|
|
|
[ "$res" = "3.51552 9999 5.26552 9999 " ]
|
|
|
|
|
2015-12-17 18:21:14 +00:00
|
|
|
# GRIB-203 nearest on M-F second order boustrophedonic
|
2017-02-03 14:21:24 +00:00
|
|
|
res=`${tools_dir}/grib_get -w count=1 -l 0,0 lfpw.grib1`
|
2015-12-17 18:21:14 +00:00
|
|
|
[ "$res" = "20560.7 20563.4 20554.7 20559.5 " ]
|
2014-07-25 10:13:00 +00:00
|
|
|
|
2017-03-27 15:23:25 +00:00
|
|
|
# Unpack/pack test for second order grib1 data
|
|
|
|
# --------------------------------------------
|
|
|
|
g1files="lfpw.grib1
|
|
|
|
gen_ext_spd_2.grib
|
|
|
|
gen_ext_spd_3.grib"
|
2021-03-12 12:23:17 +00:00
|
|
|
temp1=temp1.grib_second_order.grib
|
2017-04-05 11:49:16 +00:00
|
|
|
temp_stat1=temp.grib_second_order.stat1
|
|
|
|
temp_stat2=temp.grib_second_order.stat2
|
2017-03-27 15:23:25 +00:00
|
|
|
|
|
|
|
for f1 in $g1files; do
|
|
|
|
# This does unpack and repack
|
2021-03-12 12:23:17 +00:00
|
|
|
${tools_dir}/grib_copy -r $f1 $temp1
|
|
|
|
${tools_dir}/grib_get -n statistics $f1 > $temp_stat1
|
|
|
|
${tools_dir}/grib_get -n statistics $temp1 > $temp_stat2
|
2017-03-27 15:23:25 +00:00
|
|
|
perl ${test_dir}/number_compare.pl $temp_stat1 $temp_stat2
|
|
|
|
done
|
2021-03-12 12:23:17 +00:00
|
|
|
|
|
|
|
# GRIB-883
|
|
|
|
# ------------
|
|
|
|
# Two coded values: Should stay as grid_simple
|
|
|
|
temp2=temp2.grib_second_order.grib
|
|
|
|
temp3=temp3.grib_second_order.grib
|
|
|
|
cat > $test_filter<<EOF
|
|
|
|
set values={ 2.1, 3.4 };
|
|
|
|
write;
|
|
|
|
EOF
|
|
|
|
${tools_dir}/grib_filter -o $temp2 $test_filter $ECCODES_SAMPLES_PATH/GRIB2.tmpl
|
|
|
|
${tools_dir}/grib_set -r -s packingType=grid_second_order $temp2 $temp3
|
|
|
|
grib_check_key_equals $temp3 packingType grid_simple
|
|
|
|
|
|
|
|
# Three coded values: Now we can change to 2nd order
|
|
|
|
cat > $test_filter<<EOF
|
|
|
|
set values={ 2.1, 3.4, 8.9 };
|
|
|
|
write;
|
|
|
|
EOF
|
|
|
|
${tools_dir}/grib_filter -o $temp2 $test_filter $ECCODES_SAMPLES_PATH/GRIB2.tmpl
|
|
|
|
${tools_dir}/grib_set -r -s packingType=grid_second_order $temp2 $temp3
|
|
|
|
grib_check_key_equals $temp3 packingType grid_second_order
|
|
|
|
|
|
|
|
|
|
|
|
# Clean up
|
2017-04-05 11:49:16 +00:00
|
|
|
rm -f $temp_stat1 $temp_stat2
|
2021-03-12 12:23:17 +00:00
|
|
|
rm -f $temp1 $temp2 $temp3 $sec_ord_bmp
|
2017-04-05 11:49:16 +00:00
|
|
|
rm -f $test_filter
|