mirror of https://github.com/ecmwf/eccodes.git
76 lines
2.1 KiB
Modula-2
76 lines
2.1 KiB
Modula-2
# Copyright 2005-2013 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.
|
|
#
|
|
|
|
# moved here to allow different bitsPerValue in second order packing
|
|
unsigned[1] bitsPerValue : dump ;
|
|
alias numberOfBitsContainingEachPackedValue = bitsPerValue;
|
|
constant constantFieldHalfByte=8;
|
|
|
|
# For grib1 -> grib2
|
|
#constant dataRepresentationTemplateNumber = 0;
|
|
|
|
position offsetBeforeData;
|
|
|
|
if( bitmapPresent || !GDSPresent ) {
|
|
# For grib1 -> grib2
|
|
constant bitMapIndicator = 0;
|
|
|
|
meta codedValues data_g1simple_packing(
|
|
#simple_packing args
|
|
section4Length,
|
|
offsetBeforeData,
|
|
offsetSection4,
|
|
unitsFactor,
|
|
unitsBias,
|
|
changingPrecision,
|
|
numberOfCodedValues,
|
|
bitsPerValue,
|
|
referenceValue,
|
|
binaryScaleFactor,
|
|
decimalScaleFactor,
|
|
#g1simple_packing args
|
|
halfByte,
|
|
packingType,
|
|
grid_ieee,precision
|
|
) : read_only;
|
|
meta values data_apply_bitmap(codedValues,bitmap,missingValue,binaryScaleFactor) : dump;
|
|
alias data.packedValues = codedValues;
|
|
} else {
|
|
|
|
# For grib1 -> grib2
|
|
constant bitMapIndicator = 255;
|
|
|
|
meta values data_g1simple_packing(
|
|
section4Length,
|
|
offsetBeforeData,
|
|
offsetSection4,
|
|
unitsFactor,
|
|
unitsBias,
|
|
changingPrecision,
|
|
numberOfCodedValues,
|
|
bitsPerValue,
|
|
referenceValue,
|
|
binaryScaleFactor,
|
|
decimalScaleFactor,
|
|
halfByte,
|
|
packingType,
|
|
grid_ieee,precision
|
|
) : dump;
|
|
alias data.packedValues = values;
|
|
}
|
|
|
|
|
|
|
|
meta numberOfCodedValues number_of_coded_values(bitsPerValue,offsetBeforeData,offsetAfterData,halfByte,numberOfValues) : dump;
|
|
|
|
meta packingError simple_packing_error(bitsPerValue,binaryScaleFactor,decimalScaleFactor,referenceValue,ibm) : no_copy;
|
|
meta unpackedError simple_packing_error(zero,binaryScaleFactor,decimalScaleFactor,referenceValue,ieee) : no_copy;
|
|
template statistics "common/statistics_grid.def";
|
|
|