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.
|
2013-03-25 14:23:07 +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.
|
|
|
|
#
|
|
|
|
|
2022-04-03 22:02:48 +00:00
|
|
|
. ./include.ctest.sh
|
2013-03-25 12:04:10 +00:00
|
|
|
|
2023-12-14 13:35:47 +00:00
|
|
|
label="grib_multi_test"
|
2024-04-04 12:36:34 +00:00
|
|
|
tmpdata=temp.$label.grib
|
2015-01-26 15:50:33 +00:00
|
|
|
rm -f $tmpdata
|
2013-03-25 12:04:10 +00:00
|
|
|
|
2017-02-03 14:21:24 +00:00
|
|
|
parameterNumber=`${tools_dir}/grib_get -p parameterNumber -w parameterCategory=2,parameterNumber=3 ${data_dir}/multi.grib2`
|
2023-12-14 13:35:47 +00:00
|
|
|
if [ -z "$parameterNumber" ]; then
|
|
|
|
echo '---------- grib_get failure'
|
2013-03-25 12:04:10 +00:00
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
2017-02-03 14:21:24 +00:00
|
|
|
${tools_dir}/grib_copy -w parameterCategory=2,parameterNumber=3 ${data_dir}/multi.grib2 $tmpdata.1
|
|
|
|
${tools_dir}/grib_compare ${data_dir}/v.grib2 $tmpdata.1
|
2013-03-25 12:04:10 +00:00
|
|
|
|
|
|
|
cat > $tmpdata.rules <<EOF
|
2023-12-14 13:35:47 +00:00
|
|
|
if ( parameterCategory==2 && parameterNumber==3) {
|
|
|
|
print "[parameterNumber]";
|
|
|
|
}
|
2013-03-25 12:04:10 +00:00
|
|
|
EOF
|
|
|
|
|
2017-02-03 14:21:24 +00:00
|
|
|
parameterNumber=`${tools_dir}/grib_filter $tmpdata.rules ${data_dir}/multi.grib2`
|
2023-12-14 13:35:47 +00:00
|
|
|
if [ -z "$parameterNumber" ]; then
|
|
|
|
echo '---------- grib_filter failure'
|
2013-03-25 12:04:10 +00:00
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
2024-04-04 12:36:34 +00:00
|
|
|
# Convert to single-field
|
|
|
|
# -----------------------
|
|
|
|
infile=${data_dir}/multi.grib2
|
|
|
|
${tools_dir}/grib_copy $infile $tmpdata
|
|
|
|
c1=$(${tools_dir}/grib_count $infile)
|
|
|
|
c2=$(${tools_dir}/grib_count $tmpdata)
|
|
|
|
[ $c1 -eq 30 ]
|
|
|
|
[ $c2 -eq 56 ]
|
|
|
|
|
|
|
|
|
|
|
|
# Clean up
|
|
|
|
rm -f $tmpdata
|
2017-04-05 17:31:35 +00:00
|
|
|
rm -f $tmpdata.1 $tmpdata.rules
|