2013-03-25 12:04:10 +00:00
|
|
|
#!/bin/sh
|
2015-12-31 12:44:51 +00:00
|
|
|
# Copyright 2005-2016 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.
|
2014-08-28 09:03:16 +00:00
|
|
|
#
|
2013-03-25 12:04:10 +00:00
|
|
|
# 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
|
|
|
|
|
2014-05-07 13:14:42 +00:00
|
|
|
files="
|
|
|
|
constant_width_bitmap.grib
|
|
|
|
constant_width_boust_bitmap.grib
|
|
|
|
gen.grib
|
|
|
|
gen_bitmap.grib
|
|
|
|
gen_ext.grib
|
|
|
|
gen_ext_bitmap.grib
|
|
|
|
gen_ext_boust.grib
|
|
|
|
gen_ext_boust_bitmap.grib
|
|
|
|
gen_ext_spd_2.grib
|
|
|
|
gen_ext_spd_2_bitmap.grib
|
|
|
|
gen_ext_spd_2_boust_bitmap.grib
|
|
|
|
gen_ext_spd_3.grib
|
|
|
|
gen_ext_spd_3_boust_bitmap.grib
|
|
|
|
grid_ieee.grib
|
|
|
|
gts.grib
|
|
|
|
in_copy.grib
|
|
|
|
index.grib
|
|
|
|
mixed.grib
|
|
|
|
pad.grib
|
|
|
|
row.grib
|
|
|
|
satellite.grib
|
|
|
|
simple.grib
|
|
|
|
simple_bitmap.grib
|
|
|
|
sst_globus0083.grib
|
|
|
|
timeRangeIndicator_0.grib
|
|
|
|
timeRangeIndicator_10.grib
|
|
|
|
timeRangeIndicator_5.grib
|
|
|
|
tp_ecmwf.grib
|
|
|
|
constant_field.grib1
|
|
|
|
lfpw.grib1
|
|
|
|
missing_field.grib1
|
|
|
|
reduced_gaussian_lsm.grib1
|
|
|
|
reduced_gaussian_model_level.grib1
|
|
|
|
reduced_gaussian_pressure_level.grib1
|
|
|
|
reduced_gaussian_pressure_level_constant.grib1
|
|
|
|
reduced_gaussian_sub_area.grib1
|
|
|
|
reduced_gaussian_surface.grib1
|
|
|
|
reduced_latlon_surface.grib1
|
|
|
|
reduced_latlon_surface_constant.grib1
|
|
|
|
reference_ensemble_mean.grib1
|
|
|
|
reference_stdev.grib1
|
|
|
|
regular_gaussian_model_level.grib1
|
|
|
|
regular_gaussian_pressure_level.grib1
|
|
|
|
regular_gaussian_pressure_level_constant.grib1
|
|
|
|
regular_gaussian_surface.grib1
|
|
|
|
regular_latlon_surface.grib1
|
|
|
|
regular_latlon_surface_constant.grib1
|
|
|
|
second_ord_rbr.grib1
|
|
|
|
small_ensemble.grib1
|
|
|
|
spectral_compex.grib1
|
|
|
|
spectral_complex.grib1
|
|
|
|
spherical_model_level.grib1
|
|
|
|
spherical_pressure_level.grib1
|
|
|
|
test.grib1
|
|
|
|
gep10.t12z.pgrb2af78.grib2
|
|
|
|
gfs.c255.grib2
|
|
|
|
jpeg.grib2
|
|
|
|
lfpw.grib2
|
|
|
|
missing.grib2
|
|
|
|
multi.grib2
|
|
|
|
multi_created.grib2
|
|
|
|
reduced_gaussian_surface_jpeg.grib2
|
|
|
|
sample.grib2
|
|
|
|
test_uuid.grib2
|
|
|
|
tigge.sm.grib2
|
|
|
|
tigge.sm.miss.grib2
|
|
|
|
tigge_af_ecmwf.grib2
|
|
|
|
tigge_cf_ecmwf.grib2
|
|
|
|
tigge_ecmwf.grib2
|
|
|
|
tigge_pf_ecmwf.grib2
|
|
|
|
v.grib2
|
|
|
|
"
|
|
|
|
|
|
|
|
# Make sure the key "bitsPerValue" is defined for all gribs
|
|
|
|
# grib_get will fail if the key is not defined
|
|
|
|
for file in $files; do
|
|
|
|
infile=${data_dir}/$file
|
|
|
|
if [ -f "$infile" ]; then
|
|
|
|
${tools_dir}grib_get -p bitsPerValue $infile >/dev/null
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
|
|
|
|
2013-03-25 12:04:10 +00:00
|
|
|
files="regular_latlon_surface.grib2 \
|
|
|
|
regular_latlon_surface.grib1"
|
|
|
|
|
|
|
|
for file in `echo $files`; do
|
|
|
|
|
|
|
|
infile=${data_dir}/$file
|
|
|
|
outfile1=${infile}_bitsPerValue_1
|
|
|
|
outfile2=${infile}_bitsPerValue_2
|
|
|
|
|
|
|
|
${tools_dir}grib_set -r -s bitsPerValue=10 $infile $outfile1
|
|
|
|
|
|
|
|
${tools_dir}grib_set -s setBitsPerValue=10 $infile $outfile2
|
|
|
|
|
|
|
|
${tools_dir}grib_compare $outfile1 $outfile2
|
|
|
|
|
|
|
|
rm -f $outfile1 $outfile2 || true
|
|
|
|
|
|
|
|
done
|
|
|
|
|
|
|
|
# Extra test for grid_complex_spatial_differencing
|
2013-12-13 12:57:32 +00:00
|
|
|
res=`${tools_dir}grib_get -p decimalScaleFactor,bitsPerValue ${data_dir}/gfs.c255.grib2`
|
|
|
|
[ "$res" = "1 20" ]
|