#!/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 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_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 files="regular_latlon_surface.grib2 regular_latlon_surface.grib1 lfpw.grib1" for file in $files; do infile=${data_dir}/$file outfile1=${infile}_bitsPerValue_1 outfile2=${infile}_bitsPerValue_2 # Setting with setBitsPerValue key should be identical to using the repack option ${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 done # Extra test for grid_complex_spatial_differencing res=`${tools_dir}/grib_get -p decimalScaleFactor,bitsPerValue ${data_dir}/gfs.c255.grib2` [ "$res" = "1 20" ] # Test increasing bits per value input=${data_dir}/sample.grib2 temp=temp.grib_bitsPerValue.grib MAX_BPV=58 if [ $ECCODES_ON_WINDOWS -eq 1 ]; then MAX_BPV=26 fi stats1=`${tools_dir}/grib_get -M -F%.3f -p min,max,avg,sd $input` grib_check_key_equals $input 'bitsPerValue,packingType' '16 grid_simple' for bpv in `seq 17 $MAX_BPV`; do ${tools_dir}/grib_set -M -s setBitsPerValue=$bpv $input $temp stats2=`${tools_dir}/grib_get -M -F%.3f -p min,max,avg,sd $temp` [ "$stats1" = "$stats2" ] rm -f $temp done # Cater for case of constant field with bitsPerValue > 0 # TODO: This is a crazy case - still not sure if we should cater for it #sample2=$ECCODES_SAMPLES_PATH/GRIB2.tmpl #${tools_dir}/grib_set -s bitsPerValue=16 $sample2 $temp #minmax=`${tools_dir}/grib_get -p min,max $temp` #[ "$minmax" = "1 1" ] rm -f $temp