2023-08-17 14:30:06 +00:00
|
|
|
#!/bin/sh
|
|
|
|
# (C) Copyright 2005- ECMWF.
|
|
|
|
#
|
|
|
|
# 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.ctest.sh
|
|
|
|
|
2023-12-03 12:31:04 +00:00
|
|
|
# See JIRA issues ECC-1620, ECC-1238
|
|
|
|
# -----------------------------------
|
|
|
|
|
2024-04-13 11:33:09 +00:00
|
|
|
label="grib_sub_hourly"
|
|
|
|
temp=temp.1.$label
|
|
|
|
temp2=temp.2.$label
|
|
|
|
tempFilt=temp.$label.filt
|
|
|
|
tempText=temp.$label.txt
|
|
|
|
|
|
|
|
sample_g2=$ECCODES_SAMPLES_PATH/GRIB2.tmpl
|
|
|
|
|
2023-08-23 01:08:51 +00:00
|
|
|
grib_expect_failure()
|
|
|
|
{
|
|
|
|
a_file=$1
|
|
|
|
a_params=$2
|
|
|
|
${tools_dir}/grib_get $a_params $a_file > /dev/null 2>&1
|
|
|
|
if [ $? -eq 0 ]; then
|
|
|
|
echo "File: '$a_file'"
|
|
|
|
echo "Key(s): '$a_params'"
|
|
|
|
echo "Expected: 'failure'"
|
|
|
|
echo "Result: 'success'"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2023-08-17 14:30:06 +00:00
|
|
|
grib_check_key_equals()
|
|
|
|
{
|
|
|
|
a_file=$1
|
|
|
|
a_params=$2
|
|
|
|
a_expected=$3
|
|
|
|
a_result=`${tools_dir}/grib_get $a_params $a_file`
|
|
|
|
if [ "$a_result" != "$a_expected" ]; then
|
|
|
|
echo "File: '$a_file'"
|
|
|
|
echo "Key(s): '$a_params'"
|
|
|
|
echo "Expected: '$a_expected'"
|
|
|
|
echo "Result: '$a_result'"
|
2023-08-25 06:10:07 +00:00
|
|
|
${tools_dir}/grib_dump -O $a_file | grep -E "indicatorOfUnitOfTimeRange|lengthOfTimeRange|indicatorOfUnitForTimeRange|forecastTime"
|
2023-08-17 14:30:06 +00:00
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2023-12-01 13:12:04 +00:00
|
|
|
HOUR=""
|
2024-01-23 13:49:13 +00:00
|
|
|
if (set -u; : ${ECCODES_GRIB_HOURLY_STEPS_WITH_UNITS?}) 2> /dev/null; then
|
|
|
|
if [ $ECCODES_GRIB_HOURLY_STEPS_WITH_UNITS -gt 0 ]; then
|
2023-12-01 13:12:04 +00:00
|
|
|
export HOUR="h"
|
|
|
|
fi
|
|
|
|
fi
|
2023-11-29 14:56:48 +00:00
|
|
|
|
2023-12-01 16:26:54 +00:00
|
|
|
|
2023-11-29 14:22:36 +00:00
|
|
|
instantaneous_field=$data_dir/reduced_gaussian_surface.grib2
|
|
|
|
accumulated_field=$data_dir/reduced_gaussian_sub_area.grib2
|
|
|
|
|
2024-07-30 11:55:04 +00:00
|
|
|
# ECC-1855: Bad step initialisation
|
|
|
|
${tools_dir}/grib_set -s productDefinitionTemplateNumber=11,forecastTime=2184,indicatorOfUnitForForecastTime=1,lengthOfTimeRange=720,indicatorOfUnitForTimeRange=1,typeOfTimeIncrement=2,numberOfTimeRange=2 $accumulated_field $temp
|
|
|
|
${tools_dir}/grib_ls $temp
|
|
|
|
grib_check_key_equals $temp "-p stepRange" "2184-2904"
|
|
|
|
|
2024-06-11 09:14:33 +00:00
|
|
|
# ECC-1802: Relaxation of the "Step Units Rule":
|
|
|
|
# The updated rule permits the simultaneous assignment of the same step unit to both 'stepUnits' and 'step*' keys
|
|
|
|
in="$instantaneous_field"
|
|
|
|
low_level_keys="forecastTime,indicatorOfUnitOfTimeRange:s"
|
|
|
|
${tools_dir}/grib_set -s stepUnits=s,step=11s $in $temp
|
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "11 s"
|
|
|
|
${tools_dir}/grib_set -s stepUnits=m,step=11m $in $temp
|
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "11 m"
|
|
|
|
${tools_dir}/grib_set -s stepUnits=h,step=11h $in $temp
|
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "11 h"
|
|
|
|
${tools_dir}/grib_set -s step=11s,stepUnits=s $in $temp
|
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "11 s"
|
|
|
|
${tools_dir}/grib_set -s step=11m,stepUnits=m $in $temp
|
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "11 m"
|
|
|
|
${tools_dir}/grib_set -s step=11h,stepUnits=h $in $temp
|
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "11 h"
|
|
|
|
|
|
|
|
in="$accumulated_field"
|
|
|
|
low_level_keys="forecastTime,indicatorOfUnitOfTimeRange:s,lengthOfTimeRange,indicatorOfUnitForTimeRange:s"
|
|
|
|
${tools_dir}/grib_set -s stepUnits=s,stepRange=11s-181s $in $temp
|
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "11 s 170 s"
|
|
|
|
${tools_dir}/grib_set -s stepUnits=m,stepRange=11m-181m $in $temp
|
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "11 m 170 m"
|
|
|
|
${tools_dir}/grib_set -s stepUnits=h,stepRange=11h-181h $in $temp
|
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "11 h 170 h"
|
|
|
|
${tools_dir}/grib_set -s stepRange=11s-181s,stepUnits=s $in $temp
|
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "11 s 170 s"
|
|
|
|
${tools_dir}/grib_set -s stepRange=11m-181m,stepUnits=m $in $temp
|
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "11 m 170 m"
|
|
|
|
${tools_dir}/grib_set -s stepRange=11h-181h,stepUnits=h $in $temp
|
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "11 h 170 h"
|
2024-04-24 17:17:54 +00:00
|
|
|
|
2024-04-24 17:35:55 +00:00
|
|
|
# ECC-1813: Test that we can set the stepUnits without setting the step
|
2024-05-03 13:49:22 +00:00
|
|
|
in="$instantaneous_field"
|
2024-04-24 17:34:33 +00:00
|
|
|
low_level_keys="forecastTime,indicatorOfUnitOfTimeRange:s"
|
2024-05-03 13:49:22 +00:00
|
|
|
${tools_dir}/grib_set -s stepUnits=m,step=60 $in $temp
|
2024-04-24 17:34:33 +00:00
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "60 m"
|
|
|
|
${tools_dir}/grib_set -s stepUnits=s $temp $temp2
|
|
|
|
grib_check_key_equals $temp2 "-p $low_level_keys" "3600 s"
|
2024-05-03 13:49:22 +00:00
|
|
|
${tools_dir}/grib_set -s stepUnits=m $temp $temp2
|
|
|
|
grib_check_key_equals $temp2 "-p $low_level_keys" "60 m"
|
2024-04-24 17:34:33 +00:00
|
|
|
${tools_dir}/grib_set -s stepUnits=h $temp $temp2
|
|
|
|
grib_check_key_equals $temp2 "-p $low_level_keys" "1 h"
|
2024-04-24 17:17:54 +00:00
|
|
|
|
2024-05-03 13:49:22 +00:00
|
|
|
in="$accumulated_field"
|
2024-04-24 17:34:33 +00:00
|
|
|
low_level_keys="forecastTime,indicatorOfUnitOfTimeRange:s,lengthOfTimeRange,indicatorOfUnitForTimeRange:s"
|
2024-05-03 13:49:22 +00:00
|
|
|
${tools_dir}/grib_set -s stepUnits=m,stepRange=60-180 $in $temp
|
2024-04-24 17:34:33 +00:00
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "60 m 120 m"
|
|
|
|
${tools_dir}/grib_set -s stepUnits=s $temp $temp2
|
|
|
|
grib_check_key_equals $temp2 "-p $low_level_keys" "3600 s 7200 s"
|
2024-05-03 13:49:22 +00:00
|
|
|
${tools_dir}/grib_set -s stepUnits=m $temp $temp2
|
|
|
|
grib_check_key_equals $temp2 "-p $low_level_keys" "60 m 120 m"
|
2024-04-24 17:34:33 +00:00
|
|
|
${tools_dir}/grib_set -s stepUnits=h $temp $temp2
|
|
|
|
grib_check_key_equals $temp2 "-p $low_level_keys" "1 h 2 h"
|
2024-04-24 17:17:54 +00:00
|
|
|
|
2024-01-17 12:12:21 +00:00
|
|
|
# Check the lowercase alias 'stepunits' for a variety of step types (instant, accum etc)
|
|
|
|
${tools_dir}/grib_get -p stepunits $data_dir/tigge_cf_ecmwf.grib2
|
|
|
|
|
2023-12-01 12:51:22 +00:00
|
|
|
|
2023-12-01 16:26:54 +00:00
|
|
|
#### Make sure that step, stepRange, startStep, endStep produce the same result for instantaneous fields
|
2024-05-03 13:49:22 +00:00
|
|
|
in="$instantaneous_field"
|
2023-12-01 12:51:22 +00:00
|
|
|
low_level_keys="forecastTime,indicatorOfUnitOfTimeRange:s"
|
|
|
|
keys_step="step,step:s,step:i,step:d,stepUnits:s"
|
|
|
|
keys_step_range="stepRange,stepRange:s,stepRange:i,stepRange:d,stepUnits:s"
|
|
|
|
keys_start_step="startStep,startStep:s,startStep:i,startStep:d,stepUnits:s"
|
|
|
|
keys_end_step="endStep,endStep:s,endStep:i,endStep:d,stepUnits:s"
|
2024-05-03 13:49:22 +00:00
|
|
|
${tools_dir}/grib_set -s forecastTime=0,indicatorOfUnitOfTimeRange=h $in $temp
|
2023-12-01 16:26:54 +00:00
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "0 h"
|
2024-05-03 13:49:22 +00:00
|
|
|
${tools_dir}/grib_set -s stepUnits=m,step=59 $in $temp
|
2023-12-01 12:51:22 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys_step" "59m 59m 59 59 m"
|
|
|
|
grib_check_key_equals $temp "-p $keys_step_range" "59m 59m 59 59 m"
|
|
|
|
grib_check_key_equals $temp "-p $keys_start_step" "59m 59m 59 59 m"
|
|
|
|
grib_check_key_equals $temp "-p $keys_end_step" "59m 59m 59 59 m"
|
|
|
|
|
2024-05-03 13:49:22 +00:00
|
|
|
${tools_dir}/grib_set -s forecastTime=0,indicatorOfUnitOfTimeRange=h $in $temp
|
2023-12-01 16:26:54 +00:00
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "0 h"
|
2024-05-03 13:49:22 +00:00
|
|
|
${tools_dir}/grib_set -s step=59m $in $temp
|
2023-12-01 16:26:54 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys_step" "59m 59m 59 59 m"
|
|
|
|
grib_check_key_equals $temp "-p $keys_step_range" "59m 59m 59 59 m"
|
|
|
|
grib_check_key_equals $temp "-p $keys_start_step" "59m 59m 59 59 m"
|
|
|
|
grib_check_key_equals $temp "-p $keys_end_step" "59m 59m 59 59 m"
|
2023-12-01 12:51:22 +00:00
|
|
|
|
2023-12-01 16:26:54 +00:00
|
|
|
#### stepUnits overrides the units in the low level keys
|
|
|
|
# if stepUnits=UNIT is set, then set the low level keys to UNIT
|
2023-11-29 14:36:54 +00:00
|
|
|
# else optimise low level keys
|
2023-11-29 14:22:36 +00:00
|
|
|
# instant fields:
|
|
|
|
low_level_keys="forecastTime,indicatorOfUnitOfTimeRange:s,lengthOfTimeRange,indicatorOfUnitForTimeRange:s"
|
2024-05-03 13:49:22 +00:00
|
|
|
in="$instantaneous_field"
|
2023-11-29 14:22:36 +00:00
|
|
|
low_level_keys="forecastTime,indicatorOfUnitOfTimeRange:s"
|
|
|
|
keys__="step,stepUnits:s"
|
|
|
|
keys_s="step:s"
|
|
|
|
keys_i="step:i,stepUnits:s"
|
|
|
|
keys_d="step:d,stepUnits:s"
|
|
|
|
|
2024-05-03 13:49:22 +00:00
|
|
|
${tools_dir}/grib_set -s stepUnits=m,step=60 $in $temp
|
2023-11-29 14:36:54 +00:00
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "60 m"
|
2023-11-29 14:56:48 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys_s" "1$HOUR"
|
2023-11-29 14:36:54 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys_s -s stepUnits=m" "60m"
|
2024-05-03 13:49:22 +00:00
|
|
|
${tools_dir}/grib_set -s stepUnits=m,step=60 $in $temp
|
2023-11-29 14:22:36 +00:00
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "60 m"
|
2023-11-29 14:56:48 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys_s" "1$HOUR"
|
2023-11-29 14:22:36 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys_s -s stepUnits=m" "60m"
|
2024-05-03 13:49:22 +00:00
|
|
|
${tools_dir}/grib_set -s step=60m $in $temp
|
2023-11-29 14:22:36 +00:00
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "1 h"
|
2023-11-29 14:56:48 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys_s" "1$HOUR"
|
2023-11-29 14:22:36 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys_s -s stepUnits=m" "60m"
|
|
|
|
|
|
|
|
|
|
|
|
# accumulated fields:
|
2024-05-03 13:49:22 +00:00
|
|
|
in="$accumulated_field"
|
2023-11-29 14:22:36 +00:00
|
|
|
low_level_keys="forecastTime,indicatorOfUnitOfTimeRange:s,lengthOfTimeRange,indicatorOfUnitForTimeRange:s"
|
|
|
|
keys__="step,startStep,endStep,stepRange,stepUnits:s"
|
|
|
|
keys_s="step:s,startStep:s,endStep:s,stepRange:s,stepUnits:s"
|
|
|
|
keys_i="step:i,startStep:i,endStep:i,stepRange:i,stepUnits:s"
|
|
|
|
keys_d="step:d,startStep:d,endStep:d,stepRange:d,stepUnits:s"
|
|
|
|
|
2024-05-03 13:49:22 +00:00
|
|
|
${tools_dir}/grib_set -s stepUnits=m,stepRange=60-120 $in $temp
|
2023-11-29 14:36:54 +00:00
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "60 m 60 m"
|
2023-11-29 14:56:48 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys_s" "2$HOUR 1$HOUR 2$HOUR 1$HOUR-2$HOUR h"
|
2023-11-29 14:36:54 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys_s -s stepUnits=m" "120m 60m 120m 60m-120m m"
|
2024-05-03 13:49:22 +00:00
|
|
|
${tools_dir}/grib_set -s stepUnits=m,stepRange=60-120 $in $temp
|
2023-11-29 14:22:36 +00:00
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "60 m 60 m"
|
2023-11-29 14:56:48 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys_s" "2$HOUR 1$HOUR 2$HOUR 1$HOUR-2$HOUR h"
|
2023-11-29 14:22:36 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys_s -s stepUnits=m" "120m 60m 120m 60m-120m m"
|
2024-05-03 13:49:22 +00:00
|
|
|
${tools_dir}/grib_set -s stepRange=60m-120m $in $temp
|
2023-11-29 14:22:36 +00:00
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "1 h 1 h"
|
2023-11-29 14:56:48 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys_s" "2$HOUR 1$HOUR 2$HOUR 1$HOUR-2$HOUR h"
|
2023-11-29 14:22:36 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys_s -s stepUnits=m" "120m 60m 120m 60m-120m m"
|
2023-10-16 09:04:58 +00:00
|
|
|
|
2023-11-29 14:36:54 +00:00
|
|
|
|
2023-11-06 10:18:01 +00:00
|
|
|
#### CHECK units
|
2024-05-03 13:49:22 +00:00
|
|
|
in="$accumulated_field"
|
2023-11-06 10:18:01 +00:00
|
|
|
low_level_keys="forecastTime,indicatorOfUnitOfTimeRange:s,lengthOfTimeRange,indicatorOfUnitForTimeRange:s"
|
2024-05-03 13:49:22 +00:00
|
|
|
${tools_dir}/grib_set -s forecastTime=0,indicatorOfUnitOfTimeRange=h,lengthOfTimeRange=96,indicatorOfUnitForTimeRange=h $in $temp
|
2023-11-06 10:18:01 +00:00
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "0 h 96 h"
|
|
|
|
|
|
|
|
grib_check_key_equals $temp " -w count=1 -s stepUnits=s -p step:i,stepUnits:s" "345600 s"
|
|
|
|
grib_check_key_equals $temp " -w count=1 -s stepUnits=m -p step:i,stepUnits:s" "5760 m"
|
|
|
|
grib_check_key_equals $temp " -w count=1 -s stepUnits=15m -p step:i,stepUnits:s" "384 15m"
|
|
|
|
grib_check_key_equals $temp " -w count=1 -s stepUnits=30m -p step:i,stepUnits:s" "192 30m"
|
|
|
|
grib_check_key_equals $temp " -w count=1 -s stepUnits=h -p step:i,stepUnits:s" "96 h"
|
|
|
|
grib_check_key_equals $temp " -w count=1 -s stepUnits=6h -p step:i,stepUnits:s" "16 6h"
|
|
|
|
grib_check_key_equals $temp " -w count=1 -s stepUnits=12h -p step:i,stepUnits:s" "8 12h"
|
|
|
|
grib_check_key_equals $temp " -w count=1 -s stepUnits=D -p step:i,stepUnits:s" "4 D"
|
|
|
|
|
|
|
|
grib_check_key_equals $temp " -w count=1 -s stepUnits=s -p step,stepUnits:s" "345600s s"
|
|
|
|
grib_check_key_equals $temp " -w count=1 -s stepUnits=m -p step,stepUnits:s" "5760m m"
|
2023-11-29 09:37:38 +00:00
|
|
|
grib_check_key_equals $temp " -w count=1 -s stepUnits=15m -p step,stepUnits:s" "384x15m 15m"
|
|
|
|
grib_check_key_equals $temp " -w count=1 -s stepUnits=30m -p step,stepUnits:s" "192x30m 30m"
|
2023-11-29 14:56:48 +00:00
|
|
|
grib_check_key_equals $temp " -w count=1 -s stepUnits=h -p step,stepUnits:s" "96$HOUR h"
|
2023-11-29 09:37:38 +00:00
|
|
|
grib_check_key_equals $temp " -w count=1 -s stepUnits=6h -p step,stepUnits:s" "16x6h 6h"
|
|
|
|
grib_check_key_equals $temp " -w count=1 -s stepUnits=12h -p step,stepUnits:s" "8x12h 12h"
|
2023-11-06 10:18:01 +00:00
|
|
|
grib_check_key_equals $temp " -w count=1 -s stepUnits=D -p step,stepUnits:s" "4D D"
|
|
|
|
|
2024-05-03 13:49:22 +00:00
|
|
|
${tools_dir}/grib_set -s stepUnits=s,startStep=0,endStep=345600 $in $temp
|
2023-11-29 14:22:36 +00:00
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "0 s 345600 s"
|
2024-05-03 13:49:22 +00:00
|
|
|
${tools_dir}/grib_set -s stepUnits=m,startStep=0,endStep=5760 $in $temp
|
2023-11-29 14:22:36 +00:00
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "0 m 5760 m"
|
2024-05-03 13:49:22 +00:00
|
|
|
${tools_dir}/grib_set -s stepUnits=h,startStep=0,endStep=96 $in $temp
|
2023-11-06 10:35:52 +00:00
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "0 h 96 h"
|
2024-05-03 13:49:22 +00:00
|
|
|
${tools_dir}/grib_set -s stepUnits=6h,startStep=0,endStep=16 $in $temp
|
2023-11-29 14:22:36 +00:00
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "0 6h 16 6h"
|
2024-05-03 13:49:22 +00:00
|
|
|
${tools_dir}/grib_set -s stepUnits=12h,startStep=0,endStep=8 $in $temp
|
2023-11-29 14:22:36 +00:00
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "0 12h 8 12h"
|
2024-05-03 13:49:22 +00:00
|
|
|
${tools_dir}/grib_set -s stepUnits=D,startStep=0,endStep=4 $in $temp
|
2023-11-29 14:22:36 +00:00
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "0 D 4 D"
|
2023-11-06 10:35:52 +00:00
|
|
|
|
2023-11-06 10:18:01 +00:00
|
|
|
|
2023-10-16 09:04:58 +00:00
|
|
|
#### CHECK negative forecastTime
|
2024-05-03 13:49:22 +00:00
|
|
|
in="$accumulated_field"
|
2023-10-16 09:04:58 +00:00
|
|
|
low_level_keys="forecastTime,indicatorOfUnitOfTimeRange:s,lengthOfTimeRange,indicatorOfUnitForTimeRange:s"
|
2024-05-03 13:49:22 +00:00
|
|
|
${tools_dir}/grib_set -s forecastTime=-6,indicatorOfUnitOfTimeRange=h,lengthOfTimeRange=6,indicatorOfUnitForTimeRange=h $in $temp
|
2023-10-16 09:04:58 +00:00
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "-6 h 6 h"
|
|
|
|
|
2023-11-29 14:56:48 +00:00
|
|
|
grib_check_key_equals $temp "-s stepUnits:s=h -p startStep:s,endStep:s" "-6$HOUR 0$HOUR"
|
2023-10-16 09:04:58 +00:00
|
|
|
grib_check_key_equals $temp "-s stepUnits:s=m -p startStep:s,endStep:s" "-360m 0m"
|
|
|
|
grib_check_key_equals $temp "-s stepUnits:s=s -p startStep:s,endStep:s" "-21600s 0s"
|
|
|
|
|
2024-05-03 13:49:22 +00:00
|
|
|
${tools_dir}/grib_set -s forecastTime=-48,indicatorOfUnitOfTimeRange=h,lengthOfTimeRange=0,indicatorOfUnitForTimeRange=h $in $temp
|
2023-11-29 14:56:48 +00:00
|
|
|
grib_check_key_equals $temp "-p stepRange" "-48$HOUR"
|
2023-11-03 12:07:41 +00:00
|
|
|
|
2023-08-25 06:10:07 +00:00
|
|
|
|
2023-09-15 11:34:16 +00:00
|
|
|
#### CHECK: check optimal units are set correctly in GRIB files
|
2024-05-03 13:49:22 +00:00
|
|
|
in="$accumulated_field"
|
2023-09-15 11:34:16 +00:00
|
|
|
low_level_keys="forecastTime,indicatorOfUnitOfTimeRange:s,lengthOfTimeRange,indicatorOfUnitForTimeRange:s"
|
2024-05-03 13:49:22 +00:00
|
|
|
${tools_dir}/grib_set -s forecastTime=24,indicatorOfUnitOfTimeRange=h,lengthOfTimeRange=1,indicatorOfUnitForTimeRange=D $in $temp
|
2023-09-15 11:34:16 +00:00
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "24 h 1 D"
|
|
|
|
|
2023-11-06 10:18:01 +00:00
|
|
|
### TODO(maee): @Shahram: how to make parameters position independent
|
2023-09-21 12:57:08 +00:00
|
|
|
${tools_dir}/grib_set -s stepUnits:s=s,startStep:i=60,endStep:i=180 $temp $temp2
|
2023-11-29 14:22:36 +00:00
|
|
|
grib_check_key_equals $temp2 "-p $low_level_keys" "60 s 120 s"
|
2023-09-21 12:57:08 +00:00
|
|
|
#${tools_dir}/grib_set -s startStep:i=60,endStep:i=180,stepUnits:s=s $temp $temp2
|
|
|
|
#grib_check_key_equals $temp2 "-p $low_level_keys" "1 m 2 m"
|
|
|
|
|
2023-11-29 14:22:36 +00:00
|
|
|
# Seconds
|
2023-09-19 09:44:35 +00:00
|
|
|
${tools_dir}/grib_set -s stepUnits:i=13,startStep:i=60,endStep:i=180 $temp $temp2
|
2023-11-29 14:22:36 +00:00
|
|
|
grib_check_key_equals $temp2 "-p $low_level_keys" "60 s 120 s"
|
2023-09-19 09:44:35 +00:00
|
|
|
${tools_dir}/grib_set -s stepUnits:s=s,startStep:i=60,endStep:i=180 $temp $temp2
|
2023-11-29 14:22:36 +00:00
|
|
|
grib_check_key_equals $temp2 "-p $low_level_keys" "60 s 120 s"
|
2023-09-19 09:44:35 +00:00
|
|
|
|
2023-11-29 14:22:36 +00:00
|
|
|
# Minutes
|
2023-09-19 09:44:35 +00:00
|
|
|
${tools_dir}/grib_set -s stepUnits:i=0,startStep:i=60,endStep:i=180 $temp $temp2
|
2023-11-29 14:22:36 +00:00
|
|
|
grib_check_key_equals $temp2 "-p $low_level_keys" "60 m 120 m"
|
2023-09-19 09:44:35 +00:00
|
|
|
${tools_dir}/grib_set -s stepUnits:s=m,startStep:i=60,endStep:i=180 $temp $temp2
|
2023-11-29 14:22:36 +00:00
|
|
|
grib_check_key_equals $temp2 "-p $low_level_keys" "60 m 120 m"
|
2023-09-19 09:44:35 +00:00
|
|
|
|
2023-11-29 14:22:36 +00:00
|
|
|
# Hours
|
2023-09-19 09:44:35 +00:00
|
|
|
${tools_dir}/grib_set -s stepUnits:i=1,startStep:i=60,endStep:i=180 $temp $temp2
|
|
|
|
grib_check_key_equals $temp2 "-p $low_level_keys" "60 h 120 h"
|
|
|
|
${tools_dir}/grib_set -s stepUnits:s=h,startStep:i=60,endStep:i=180 $temp $temp2
|
|
|
|
grib_check_key_equals $temp2 "-p $low_level_keys" "60 h 120 h"
|
2023-09-15 11:34:16 +00:00
|
|
|
|
2024-05-03 13:49:22 +00:00
|
|
|
#in="$accumulated_field"
|
2023-08-31 13:30:10 +00:00
|
|
|
#low_level_keys="forecastTime,indicatorOfUnitOfTimeRange:s,lengthOfTimeRange,indicatorOfUnitForTimeRange:s"
|
|
|
|
##high_level_keys="startStep:s,endStep:s"
|
|
|
|
#high_level_keys="startStep:i,endStep:i"
|
2024-05-03 13:49:22 +00:00
|
|
|
#${tools_dir}/grib_set -s forecastTime=24,indicatorOfUnitOfTimeRange=h,lengthOfTimeRange=1,indicatorOfUnitForTimeRange=D $in $temp
|
2023-09-04 13:01:19 +00:00
|
|
|
#grib_check_key_equals $temp "-p $low_level_keys" "24 h 1 D"
|
|
|
|
#grib_check_key_equals $temp "-p $high_level_keys" "24 48"
|
|
|
|
#${tools_dir}/grib_set -s startStep:i=24 $temp $temp2
|
|
|
|
#grib_check_key_equals $temp2 "-p $low_level_keys" "24 h 0 h"
|
|
|
|
#grib_check_key_equals $temp2 "-p $high_level_keys" "24 24"
|
2023-08-31 13:30:10 +00:00
|
|
|
|
2024-05-03 13:49:22 +00:00
|
|
|
#${tools_dir}/grib_set -s forecastTime=24,indicatorOfUnitOfTimeRange=h,lengthOfTimeRange=24,indicatorOfUnitForTimeRange=h $in $temp
|
2023-09-04 13:01:19 +00:00
|
|
|
#grib_check_key_equals $temp "-p $low_level_keys" "24 h 24 h"
|
|
|
|
#grib_check_key_equals $temp "-p $high_level_keys" "24 48"
|
|
|
|
#${tools_dir}/grib_set -s startStep:i=24 $temp $temp2
|
|
|
|
#grib_check_key_equals $temp2 "-p $low_level_keys" "24 h 24 h"
|
|
|
|
#grib_check_key_equals $temp2 "-p $high_level_keys" "24 48"
|
2023-08-31 13:30:10 +00:00
|
|
|
#exit
|
|
|
|
|
2023-08-30 06:00:49 +00:00
|
|
|
#### CHECK: grib_set - endStep + stepUnits
|
2024-05-03 13:49:22 +00:00
|
|
|
in="$accumulated_field"
|
2023-08-25 06:10:07 +00:00
|
|
|
low_level_keys="forecastTime,indicatorOfUnitOfTimeRange:s,lengthOfTimeRange,indicatorOfUnitForTimeRange:s"
|
2024-05-03 13:49:22 +00:00
|
|
|
${tools_dir}/grib_set -s forecastTime=24,indicatorOfUnitOfTimeRange=h,lengthOfTimeRange=1,indicatorOfUnitForTimeRange=D $in $temp
|
2023-08-25 06:10:07 +00:00
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "24 h 1 D"
|
|
|
|
|
|
|
|
# Use range unit: hour
|
2023-11-06 10:18:01 +00:00
|
|
|
${tools_dir}/grib_set -s endStep:d=30 $temp $temp2 # TODO(maee) remove in the future behavior
|
|
|
|
#${tools_dir}/grib_set -s endStep:i=30 $temp $temp2 # TODO(maee) keep for backwards compatibility
|
2023-09-04 13:01:19 +00:00
|
|
|
#${tools_dir}/grib_set -s endStep:s=30 $temp $temp2
|
|
|
|
#${tools_dir}/grib_set -s endStep:s=30h $temp $temp2
|
2023-11-06 10:18:01 +00:00
|
|
|
#${tools_dir}/grib_set -s endStep=30h $temp $temp2 # TODO(maee) add to tests
|
2023-09-04 13:01:19 +00:00
|
|
|
grib_check_key_equals $temp2 "-p $low_level_keys" "24 h 6 h"
|
2023-08-25 06:10:07 +00:00
|
|
|
|
|
|
|
# Use stepUnits
|
2023-09-04 13:01:19 +00:00
|
|
|
${tools_dir}/grib_set -s endStep:s=30 $temp $temp2
|
2023-09-21 12:57:08 +00:00
|
|
|
grib_check_key_equals $temp2 "-p $low_level_keys" "24 h 6 h"
|
|
|
|
|
2023-09-04 13:01:19 +00:00
|
|
|
${tools_dir}/grib_set -s endStep:s=30h $temp $temp2
|
|
|
|
grib_check_key_equals $temp2 "-p $low_level_keys" "24 h 6 h"
|
2023-09-21 12:57:08 +00:00
|
|
|
|
2023-09-04 13:01:19 +00:00
|
|
|
${tools_dir}/grib_set -s endStep:s=88200s $temp $temp2
|
|
|
|
grib_check_key_equals $temp2 "-p $low_level_keys" "1440 m 30 m"
|
2023-09-21 12:57:08 +00:00
|
|
|
|
2023-09-04 13:01:19 +00:00
|
|
|
${tools_dir}/grib_set -s endStep:s=24024 $temp $temp2
|
|
|
|
grib_check_key_equals $temp2 "-p $low_level_keys" "24 h 24000 h"
|
2023-08-25 06:10:07 +00:00
|
|
|
|
2023-09-04 13:01:19 +00:00
|
|
|
${tools_dir}/grib_set -s startStep:d=5 $temp $temp2
|
|
|
|
grib_check_key_equals $temp2 "-p $low_level_keys" "5 h 43 h"
|
2023-08-25 06:10:07 +00:00
|
|
|
|
2023-09-04 13:01:19 +00:00
|
|
|
${tools_dir}/grib_set -s startStep:s=5h $temp $temp2
|
|
|
|
grib_check_key_equals $temp2 "-p $low_level_keys" "5 h 43 h"
|
2023-09-21 12:57:08 +00:00
|
|
|
|
2023-09-04 13:01:19 +00:00
|
|
|
${tools_dir}/grib_set -s startStep:s=240s $temp $temp2
|
|
|
|
grib_check_key_equals $temp2 "-p $low_level_keys" "4 m 2876 m"
|
2023-09-21 12:57:08 +00:00
|
|
|
|
2023-09-04 13:01:19 +00:00
|
|
|
${tools_dir}/grib_set -s startStep:s=2 $temp $temp2
|
|
|
|
grib_check_key_equals $temp2 "-p $low_level_keys" "2 h 46 h"
|
2023-08-25 06:10:07 +00:00
|
|
|
|
2023-09-04 13:01:19 +00:00
|
|
|
${tools_dir}/grib_set -s stepRange:s=5h-30h $temp $temp2
|
|
|
|
grib_check_key_equals $temp2 "-p $low_level_keys" "5 h 25 h"
|
2023-11-29 14:56:48 +00:00
|
|
|
grib_check_key_equals $temp2 "-p stepRange:s" "5$HOUR-30$HOUR"
|
2023-08-25 06:10:07 +00:00
|
|
|
|
2023-09-04 13:01:19 +00:00
|
|
|
${tools_dir}/grib_set -s stepRange:s=5-30 $temp $temp2
|
|
|
|
grib_check_key_equals $temp2 "-p $low_level_keys" "5 h 25 h"
|
2023-11-29 14:56:48 +00:00
|
|
|
grib_check_key_equals $temp2 "-p stepRange:s" "5$HOUR-30$HOUR"
|
2023-08-25 06:10:07 +00:00
|
|
|
|
2023-09-04 13:01:19 +00:00
|
|
|
${tools_dir}/grib_set -s stepRange:s=60m-120m $temp $temp2
|
|
|
|
grib_check_key_equals $temp2 "-p $low_level_keys" "1 h 1 h"
|
2023-11-29 14:56:48 +00:00
|
|
|
grib_check_key_equals $temp2 "-p stepRange:s" "1$HOUR-2$HOUR"
|
2023-08-25 06:10:07 +00:00
|
|
|
|
2023-09-04 13:01:19 +00:00
|
|
|
${tools_dir}/grib_set -s stepRange:s=60s-120s $temp $temp2
|
|
|
|
grib_check_key_equals $temp2 "-p $low_level_keys" "1 m 1 m"
|
|
|
|
grib_check_key_equals $temp2 "-p stepRange:s" "1m-2m"
|
2023-08-25 06:10:07 +00:00
|
|
|
|
2023-09-04 13:01:19 +00:00
|
|
|
${tools_dir}/grib_set -s stepRange:s=60m-121m $temp $temp2
|
|
|
|
grib_check_key_equals $temp2 "-p $low_level_keys" "60 m 61 m"
|
|
|
|
grib_check_key_equals $temp2 "-p stepRange:s" "60m-121m"
|
2023-08-25 06:10:07 +00:00
|
|
|
|
2023-09-04 13:01:19 +00:00
|
|
|
${tools_dir}/grib_set -s stepRange:s=62D-122D $temp $temp2
|
|
|
|
grib_check_key_equals $temp2 "-p $low_level_keys" "1488 h 1440 h"
|
2023-11-29 14:56:48 +00:00
|
|
|
grib_check_key_equals $temp2 "-p stepRange:s" "1488$HOUR-2928$HOUR"
|
2023-08-25 06:10:07 +00:00
|
|
|
|
2024-05-03 13:49:22 +00:00
|
|
|
in="$instantaneous_field"
|
2023-08-17 14:30:06 +00:00
|
|
|
low_level_keys="forecastTime,indicatorOfUnitOfTimeRange:s"
|
2023-09-15 07:10:29 +00:00
|
|
|
keys__="step,stepUnits:s"
|
2023-08-17 14:30:06 +00:00
|
|
|
keys_s="step:s"
|
2023-09-15 07:10:29 +00:00
|
|
|
keys_i="step:i,stepUnits:s"
|
|
|
|
keys_d="step:d,stepUnits:s"
|
2023-08-17 14:30:06 +00:00
|
|
|
|
2024-05-03 13:49:22 +00:00
|
|
|
${tools_dir}/grib_set -s forecastTime=59,indicatorOfUnitOfTimeRange=m $in $temp
|
2023-11-03 12:16:04 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys__ -s stepUnits=s" "3540s s"
|
|
|
|
grib_check_key_equals $temp "-p $keys__ -s stepUnits=m" "59m m"
|
2023-11-29 14:22:36 +00:00
|
|
|
#grib_check_key_equals $temp "-p $keys__ -s stepUnits=h" "0" # not supported
|
2023-09-04 13:01:19 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys_s -s stepUnits=s" "3540s"
|
|
|
|
grib_check_key_equals $temp "-p $keys_s -s stepUnits=m" "59m"
|
2023-11-29 14:22:36 +00:00
|
|
|
#grib_check_key_equals $temp "-p $keys_s -F"%.2f" -s stepUnits=h" "0.98" # not supported
|
2023-09-15 07:10:29 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys_i -s stepUnits=s" "3540 s"
|
|
|
|
grib_check_key_equals $temp "-p $keys_i -s stepUnits=m" "59 m"
|
2023-11-29 14:22:36 +00:00
|
|
|
#grib_check_key_equals $temp "-p $keys_i -s stepUnits=h" "0" # not supported
|
2023-09-15 07:10:29 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys_d -s stepUnits=s" "3540 s"
|
|
|
|
grib_check_key_equals $temp "-p $keys_d -s stepUnits=m" "59 m"
|
2023-11-29 14:22:36 +00:00
|
|
|
#grib_check_key_equals $temp "-p $keys_d -s stepUnits=h" "0.983333" # not supported
|
|
|
|
|
|
|
|
|
2024-05-03 13:49:22 +00:00
|
|
|
${tools_dir}/grib_set -s forecastTime=0,indicatorOfUnitOfTimeRange=m $in $temp
|
2023-09-15 07:10:29 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys_i -s stepUnits=s" "0 s"
|
|
|
|
grib_check_key_equals $temp "-p $keys_i -s stepUnits=m" "0 m"
|
|
|
|
grib_check_key_equals $temp "-p $keys_i -s stepUnits=h" "0 h"
|
|
|
|
grib_check_key_equals $temp "-p $keys_d -s stepUnits=s" "0 s"
|
|
|
|
grib_check_key_equals $temp "-p $keys_d -s stepUnits=m" "0 m"
|
|
|
|
grib_check_key_equals $temp "-p $keys_d -s stepUnits=h" "0 h"
|
2023-08-23 01:08:51 +00:00
|
|
|
|
|
|
|
|
2024-05-03 13:49:22 +00:00
|
|
|
in="$instantaneous_field"
|
2023-08-23 01:08:51 +00:00
|
|
|
low_level_keys="forecastTime,indicatorOfUnitOfTimeRange:s"
|
2023-09-15 07:10:29 +00:00
|
|
|
keys__="step,stepUnits:s"
|
|
|
|
keys_s="step:s,stepUnits:s"
|
|
|
|
keys_i="step:i,stepUnits:s"
|
|
|
|
keys_d="step:d,stepUnits:s"
|
2023-08-23 01:08:51 +00:00
|
|
|
|
2024-05-03 13:49:22 +00:00
|
|
|
${tools_dir}/grib_set -s forecastTime=0,indicatorOfUnitOfTimeRange=m $in $temp
|
2023-11-03 12:26:00 +00:00
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "0 m"
|
2023-11-03 12:16:04 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys__" "0m m"
|
2023-09-15 07:10:29 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys_s" "0m m"
|
|
|
|
grib_check_key_equals $temp "-p $keys_i" "0 m"
|
|
|
|
grib_check_key_equals $temp "-p $keys_d" "0 m"
|
|
|
|
|
2023-11-03 12:16:04 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys__ -s stepUnits=s" "0s s"
|
|
|
|
grib_check_key_equals $temp "-p $keys__ -s stepUnits=m" "0m m"
|
2023-11-29 14:56:48 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys__ -s stepUnits=h" "0$HOUR h"
|
2023-09-15 07:10:29 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys_s -s stepUnits=s" "0s s"
|
|
|
|
grib_check_key_equals $temp "-p $keys_s -s stepUnits=m" "0m m"
|
2023-11-29 14:56:48 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys_s -s stepUnits=h" "0$HOUR h"
|
2023-09-15 07:10:29 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys_i -s stepUnits=s" "0 s"
|
|
|
|
grib_check_key_equals $temp "-p $keys_i -s stepUnits=m" "0 m"
|
|
|
|
grib_check_key_equals $temp "-p $keys_i -s stepUnits=h" "0 h"
|
|
|
|
grib_check_key_equals $temp "-p $keys_d -s stepUnits=s" "0 s"
|
|
|
|
grib_check_key_equals $temp "-p $keys_d -s stepUnits=m" "0 m"
|
|
|
|
grib_check_key_equals $temp "-p $keys_d -s stepUnits=h" "0 h"
|
2023-08-23 01:08:51 +00:00
|
|
|
|
2023-08-17 14:30:06 +00:00
|
|
|
|
2024-05-03 13:49:22 +00:00
|
|
|
${tools_dir}/grib_set -s forecastTime=59,indicatorOfUnitOfTimeRange=m $in $temp
|
2023-11-03 12:16:04 +00:00
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "59 m"
|
|
|
|
grib_check_key_equals $temp "-p $keys__" "59m m"
|
2023-09-04 13:01:19 +00:00
|
|
|
#grib_check_key_equals $temp "-p $keys_s" "59"
|
2023-09-15 07:10:29 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys_s" "59m m"
|
|
|
|
grib_check_key_equals $temp "-p $keys_i" "59 m"
|
|
|
|
grib_check_key_equals $temp "-p $keys_d" "59 m"
|
2023-08-17 14:30:06 +00:00
|
|
|
|
2024-05-03 13:49:22 +00:00
|
|
|
${tools_dir}/grib_set -s forecastTime=60,indicatorOfUnitOfTimeRange=m $in $temp
|
2023-11-03 12:26:00 +00:00
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "60 m"
|
2023-11-29 14:56:48 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys__" "1$HOUR h"
|
|
|
|
grib_check_key_equals $temp "-p $keys_s" "1$HOUR h"
|
2023-09-15 07:10:29 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys_i" "1 h"
|
|
|
|
grib_check_key_equals $temp "-p $keys_d" "1 h"
|
2023-08-17 14:30:06 +00:00
|
|
|
|
2024-05-03 13:49:22 +00:00
|
|
|
${tools_dir}/grib_set -s forecastTime=61,indicatorOfUnitOfTimeRange=m $in $temp
|
2023-11-03 12:26:00 +00:00
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "61 m"
|
2023-11-03 12:16:04 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys__" "61m m"
|
2023-09-04 13:01:19 +00:00
|
|
|
#grib_check_key_equals $temp "-p $keys_s" "61"
|
2023-09-15 07:10:29 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys_s" "61m m"
|
|
|
|
grib_check_key_equals $temp "-p $keys_i" "61 m"
|
|
|
|
grib_check_key_equals $temp "-p $keys_d" "61 m"
|
2023-08-17 14:30:06 +00:00
|
|
|
|
2024-05-03 13:49:22 +00:00
|
|
|
${tools_dir}/grib_set -s forecastTime=24,indicatorOfUnitOfTimeRange=h $in $temp
|
2023-11-03 12:26:00 +00:00
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "24 h"
|
2023-11-29 14:56:48 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys__" "24$HOUR h"
|
|
|
|
grib_check_key_equals $temp "-p $keys_s" "24$HOUR h"
|
2023-09-15 07:10:29 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys_i" "24 h"
|
|
|
|
grib_check_key_equals $temp "-p $keys_d" "24 h"
|
2023-08-17 14:30:06 +00:00
|
|
|
|
2024-05-03 13:49:22 +00:00
|
|
|
${tools_dir}/grib_set -s forecastTime=1440,indicatorOfUnitOfTimeRange=m $in $temp
|
2023-11-03 12:26:00 +00:00
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "1440 m"
|
2023-11-29 14:56:48 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys__" "24$HOUR h"
|
|
|
|
grib_check_key_equals $temp "-p $keys_s" "24$HOUR h"
|
2023-09-15 07:10:29 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys_i" "24 h"
|
|
|
|
grib_check_key_equals $temp "-p $keys_d" "24 h"
|
2023-08-17 14:30:06 +00:00
|
|
|
|
|
|
|
|
2024-05-03 13:49:22 +00:00
|
|
|
in="$accumulated_field"
|
2023-09-04 19:06:17 +00:00
|
|
|
low_level_keys="forecastTime,indicatorOfUnitOfTimeRange:s,lengthOfTimeRange,indicatorOfUnitForTimeRange:s"
|
2024-05-03 13:49:22 +00:00
|
|
|
${tools_dir}/grib_set -s stepRange=60m-2h $in $temp
|
2023-09-04 19:06:17 +00:00
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "1 h 1 h"
|
|
|
|
|
2024-05-03 13:49:22 +00:00
|
|
|
in="$accumulated_field"
|
2023-08-17 14:30:06 +00:00
|
|
|
low_level_keys="forecastTime,indicatorOfUnitOfTimeRange:s,lengthOfTimeRange,indicatorOfUnitForTimeRange:s"
|
|
|
|
keys__="stepRange,startStep,endStep"
|
|
|
|
keys_s="stepRange:s,startStep:s,endStep:s"
|
|
|
|
keys_i="stepRange:i,startStep:i,endStep:i"
|
|
|
|
keys_d="stepRange:d,startStep:d,endStep:d"
|
|
|
|
|
2024-05-03 13:49:22 +00:00
|
|
|
${tools_dir}/grib_set -s forecastTime=0,indicatorOfUnitOfTimeRange=m,lengthOfTimeRange=2,indicatorOfUnitForTimeRange=h $in $temp
|
2023-11-03 12:26:00 +00:00
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "0 m 2 h"
|
2023-11-29 14:56:48 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys__" "0$HOUR-2$HOUR 0$HOUR 2$HOUR"
|
|
|
|
grib_check_key_equals $temp "-p $keys_s" "0$HOUR-2$HOUR 0$HOUR 2$HOUR"
|
2023-09-04 13:01:19 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys_i" "2 0 2"
|
|
|
|
grib_check_key_equals $temp "-p $keys_d" "2 0 2"
|
2023-08-17 14:30:06 +00:00
|
|
|
|
2024-05-03 13:49:22 +00:00
|
|
|
${tools_dir}/grib_set -s forecastTime=24,indicatorOfUnitOfTimeRange=h,lengthOfTimeRange=1,indicatorOfUnitForTimeRange=D $in $temp
|
2023-11-03 12:26:00 +00:00
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "24 h 1 D"
|
2023-11-29 14:56:48 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys__" "24$HOUR-48$HOUR 24$HOUR 48$HOUR"
|
|
|
|
grib_check_key_equals $temp "-p $keys_s" "24$HOUR-48$HOUR 24$HOUR 48$HOUR"
|
2023-09-04 13:01:19 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys_i" "48 24 48"
|
|
|
|
grib_check_key_equals $temp "-p $keys_d" "48 24 48"
|
2023-08-17 14:30:06 +00:00
|
|
|
|
2024-05-03 13:49:22 +00:00
|
|
|
${tools_dir}/grib_set -s forecastTime=25,indicatorOfUnitOfTimeRange=h,lengthOfTimeRange=1,indicatorOfUnitForTimeRange=D $in $temp
|
2023-11-03 12:26:00 +00:00
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "25 h 1 D"
|
2023-11-29 14:56:48 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys__" "25$HOUR-49$HOUR 25$HOUR 49$HOUR"
|
|
|
|
grib_check_key_equals $temp "-p $keys_s" "25$HOUR-49$HOUR 25$HOUR 49$HOUR"
|
2023-09-04 13:01:19 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys_i" "49 25 49"
|
|
|
|
grib_check_key_equals $temp "-p $keys_d" "49 25 49"
|
2023-08-17 16:04:30 +00:00
|
|
|
|
2024-05-03 13:49:22 +00:00
|
|
|
${tools_dir}/grib_set -s forecastTime=45,indicatorOfUnitOfTimeRange=m,lengthOfTimeRange=15,indicatorOfUnitForTimeRange=m $in $temp
|
2023-11-03 12:26:00 +00:00
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "45 m 15 m"
|
2023-11-03 12:16:04 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys__" "45m-60m 45m 60m"
|
2023-09-04 13:01:19 +00:00
|
|
|
#grib_check_key_equals $temp "-p $keys_s" "45-60 45 60"
|
|
|
|
grib_check_key_equals $temp "-p $keys_s" "45m-60m 45m 60m"
|
|
|
|
grib_check_key_equals $temp "-p $keys_i" "60 45 60"
|
|
|
|
grib_check_key_equals $temp "-p $keys_d" "60 45 60"
|
2023-08-17 16:04:30 +00:00
|
|
|
|
2024-05-03 13:49:22 +00:00
|
|
|
${tools_dir}/grib_set -s forecastTime=60,indicatorOfUnitOfTimeRange=m,lengthOfTimeRange=2,indicatorOfUnitForTimeRange=h $in $temp
|
2023-11-03 12:26:00 +00:00
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "60 m 2 h"
|
2023-11-29 14:56:48 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys__" "1$HOUR-3$HOUR 1$HOUR 3$HOUR"
|
|
|
|
grib_check_key_equals $temp "-p $keys_s" "1$HOUR-3$HOUR 1$HOUR 3$HOUR"
|
2023-09-04 13:01:19 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys_i" "3 1 3"
|
|
|
|
grib_check_key_equals $temp "-p $keys_d" "3 1 3"
|
2023-08-17 14:30:06 +00:00
|
|
|
|
2024-05-03 13:49:22 +00:00
|
|
|
${tools_dir}/grib_set -s forecastTime=18,indicatorOfUnitOfTimeRange=h,lengthOfTimeRange=6,indicatorOfUnitForTimeRange=h $in $temp
|
2023-11-03 12:26:00 +00:00
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "18 h 6 h"
|
2023-11-29 14:56:48 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys__" "18$HOUR-24$HOUR 18$HOUR 24$HOUR"
|
|
|
|
grib_check_key_equals $temp "-p $keys_s" "18$HOUR-24$HOUR 18$HOUR 24$HOUR"
|
2023-09-04 13:01:19 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys_i" "24 18 24"
|
|
|
|
grib_check_key_equals $temp "-p $keys_d" "24 18 24"
|
2023-08-17 14:30:06 +00:00
|
|
|
|
2024-05-03 13:49:22 +00:00
|
|
|
${tools_dir}/grib_set -s forecastTime=1080,indicatorOfUnitOfTimeRange=m,lengthOfTimeRange=360,indicatorOfUnitForTimeRange=m $in $temp
|
2023-11-03 12:26:00 +00:00
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "1080 m 360 m"
|
2023-11-29 14:56:48 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys__" "18$HOUR-24$HOUR 18$HOUR 24$HOUR"
|
|
|
|
grib_check_key_equals $temp "-p $keys_s" "18$HOUR-24$HOUR 18$HOUR 24$HOUR"
|
2023-09-04 13:01:19 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys_i" "24 18 24"
|
|
|
|
grib_check_key_equals $temp "-p $keys_d" "24 18 24"
|
2023-08-17 14:30:06 +00:00
|
|
|
|
2024-05-03 13:49:22 +00:00
|
|
|
${tools_dir}/grib_set -s forecastTime=1080,indicatorOfUnitOfTimeRange=m,lengthOfTimeRange=6,indicatorOfUnitForTimeRange=h $in $temp
|
2023-11-03 12:26:00 +00:00
|
|
|
grib_check_key_equals $temp "-p $low_level_keys" "1080 m 6 h"
|
2023-11-29 14:56:48 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys__" "18$HOUR-24$HOUR 18$HOUR 24$HOUR"
|
|
|
|
grib_check_key_equals $temp "-p $keys_s" "18$HOUR-24$HOUR 18$HOUR 24$HOUR"
|
2023-09-04 13:01:19 +00:00
|
|
|
grib_check_key_equals $temp "-p $keys_i" "24 18 24"
|
|
|
|
grib_check_key_equals $temp "-p $keys_d" "24 18 24"
|
2023-08-17 14:30:06 +00:00
|
|
|
|
2024-01-25 22:38:05 +00:00
|
|
|
# Pack expression
|
|
|
|
cat >$tempFilt<<EOF
|
|
|
|
set step="16m"; write;
|
|
|
|
EOF
|
|
|
|
${tools_dir}/grib_filter -o $temp $tempFilt $sample_g2
|
|
|
|
grib_check_key_equals $temp "-p indicatorOfUnitOfTimeRange,forecastTime" "0 16"
|
|
|
|
|
|
|
|
cat >$tempFilt<<EOF
|
|
|
|
set stepUnits="s"; set step="16"; write;
|
|
|
|
EOF
|
|
|
|
${tools_dir}/grib_filter -o $temp $tempFilt $sample_g2
|
|
|
|
grib_check_key_equals $temp "-p indicatorOfUnitOfTimeRange,forecastTime" "13 16"
|
|
|
|
|
|
|
|
|
|
|
|
cat >$tempFilt<<EOF
|
|
|
|
set stepUnits="s"; set step=16; write;
|
|
|
|
EOF
|
|
|
|
${tools_dir}/grib_filter -o $temp $tempFilt $sample_g2
|
|
|
|
grib_check_key_equals $temp "-p indicatorOfUnitOfTimeRange,forecastTime" "13 16"
|
|
|
|
|
|
|
|
|
2024-01-13 14:52:25 +00:00
|
|
|
cat >$tempFilt<<EOF
|
|
|
|
set stepUnits="m"; print "[step]";
|
|
|
|
EOF
|
|
|
|
${tools_dir}/grib_filter $tempFilt $data_dir/constant_field.grib2
|
|
|
|
|
|
|
|
|
|
|
|
cat >$tempFilt<<EOF
|
|
|
|
set stepUnits="s"; print "[step]";
|
|
|
|
EOF
|
|
|
|
${tools_dir}/grib_filter $tempFilt $data_dir/constant_field.grib2
|
|
|
|
|
2024-01-16 12:39:40 +00:00
|
|
|
# Setting stepUnits as integer via filter
|
|
|
|
cat >$tempFilt<<EOF
|
|
|
|
set stepUnits = 0;
|
|
|
|
set startStep = "16";
|
|
|
|
write;
|
|
|
|
EOF
|
2024-01-16 13:40:36 +00:00
|
|
|
${tools_dir}/grib_filter -o $temp $tempFilt $sample_g2
|
2024-01-16 12:39:40 +00:00
|
|
|
grib_check_key_equals $temp '-p startStep' '16m'
|
|
|
|
grib_check_key_equals $temp '-p indicatorOfUnitOfTimeRange' '0'
|
|
|
|
grib_check_key_equals $temp '-p forecastTime' '16'
|
2024-01-13 14:52:25 +00:00
|
|
|
|
2024-01-19 12:15:28 +00:00
|
|
|
|
2024-01-23 13:49:13 +00:00
|
|
|
export ECCODES_GRIB_HOURLY_STEPS_WITH_UNITS=1
|
2024-01-19 12:15:28 +00:00
|
|
|
cat >$tempFilt<<EOF
|
|
|
|
assert ( step is "6h" );
|
|
|
|
EOF
|
|
|
|
cat $tempFilt
|
|
|
|
${tools_dir}/grib_filter $tempFilt $data_dir/constant_field.grib2
|
2024-01-23 13:49:13 +00:00
|
|
|
unset ECCODES_GRIB_HOURLY_STEPS_WITH_UNITS
|
2024-01-19 12:15:28 +00:00
|
|
|
|
2024-02-19 11:26:59 +00:00
|
|
|
|
|
|
|
# Changing the product definition template
|
|
|
|
# ----------------------------------------
|
|
|
|
# See ECC-1768
|
|
|
|
${tools_dir}/grib_set -s step=62m $sample_g2 $temp
|
|
|
|
${tools_dir}/grib_set -s productDefinitionTemplateNumber=8 $temp $temp2
|
|
|
|
|
|
|
|
${tools_dir}/grib_set -s productDefinitionTemplateNumber=8,stepUnits=s,step=0 $sample_g2 $temp
|
|
|
|
grib_check_key_equals $temp '-p stepUnits:s,startStep,productDefinitionTemplateNumber' 's 0s 8'
|
|
|
|
|
|
|
|
${tools_dir}/grib_set -s productDefinitionTemplateNumber=8,stepUnits=m,step=60 $sample_g2 $temp
|
|
|
|
grib_check_key_equals $temp '-p stepUnits:s,productDefinitionTemplateNumber' 'h 8'
|
|
|
|
|
|
|
|
|
2024-01-16 13:40:36 +00:00
|
|
|
# Bad stepUnits
|
|
|
|
set +e
|
|
|
|
${tools_dir}/grib_set -s stepUnits=190 $sample_g2 $temp > $tempText 2>&1
|
|
|
|
status=$?
|
|
|
|
set -e
|
|
|
|
[ $status -ne 0 ]
|
|
|
|
grep -q "Invalid unit" $tempText
|
2024-01-13 14:52:25 +00:00
|
|
|
|
2024-04-12 10:33:00 +00:00
|
|
|
|
|
|
|
# ECC-1800: Set stepUnits before paramIds, which cause changes in the PTDN
|
2024-04-13 11:33:09 +00:00
|
|
|
${tools_dir}/grib_set -s stepUnits=m,productDefinitionTemplateNumber=40 $sample_g2 $temp
|
|
|
|
grib_check_key_equals $temp '-p indicatorOfUnitOfTimeRange,stepUnits:s,productDefinitionTemplateNumber' '0 m 40'
|
|
|
|
|
|
|
|
${tools_dir}/grib_set -s stepUnits=m,step=6,productDefinitionTemplateNumber=40 $sample_g2 $temp
|
|
|
|
grib_check_key_equals $temp '-p indicatorOfUnitOfTimeRange,stepUnits:s,forecastTime' '0 m 6'
|
|
|
|
|
2024-04-12 10:33:00 +00:00
|
|
|
${tools_dir}/grib_set -s stepUnits=s,paramId=210203 $sample_g2 $temp # is_chemical
|
|
|
|
grib_check_key_equals $temp '-p indicatorOfUnitOfTimeRange,stepUnits:s,productDefinitionTemplateNumber' '13 s 40'
|
|
|
|
|
|
|
|
${tools_dir}/grib_set -s stepUnits=s,paramId=131060 $sample_g2 $temp # probability forecasts
|
|
|
|
grib_check_key_equals $temp '-p indicatorOfUnitOfTimeRange,stepUnits:s,productDefinitionTemplateNumber' '13 s 9'
|
|
|
|
|
|
|
|
${tools_dir}/grib_set -s stepUnits=s,paramId=210073 $sample_g2 $temp # is_aerosol
|
|
|
|
grib_check_key_equals $temp '-p indicatorOfUnitOfTimeRange,stepUnits:s,productDefinitionTemplateNumber' '13 s 48'
|
|
|
|
|
|
|
|
${tools_dir}/grib_set -s stepUnits=s,paramId=210170 $sample_g2 $temp # is_chemical_srcsink
|
|
|
|
grib_check_key_equals $temp '-p indicatorOfUnitOfTimeRange,stepUnits:s,productDefinitionTemplateNumber' '13 s 76'
|
|
|
|
|
|
|
|
# Add a case with filter too
|
|
|
|
echo "set stepUnits='s'; set paramId=210203; write;" | ${tools_dir}/grib_filter -o $temp - $sample_g2
|
|
|
|
grib_check_key_equals $temp '-p indicatorOfUnitOfTimeRange,stepUnits:s,productDefinitionTemplateNumber' '13 s 40'
|
|
|
|
|
|
|
|
|
2024-01-16 12:39:40 +00:00
|
|
|
# Clean up
|
2024-01-16 13:40:36 +00:00
|
|
|
rm -f $temp $temp2 $tempFilt $tempText
|