NOTICE: This version of the NSF Unidata web site (archive.unidata.ucar.edu) is no longer being updated.
Current content can be found at unidata.ucar.edu.

Re: Conventions

I do agree with Harvey, and we did say that in "Writing NetCDF Files: Best Practices".

however, there are some important datasets that used a valid_range of unpacked data type. i felt i had to be able to read these in VariableStandardized. I think the rule is "be strict in what you write, liberal in what you read".


Russ Rew wrote:

Harvey,


...
Regarding valid_range.  The generic conventions clearly state that
the type must match that of the variable.  If if does not, then
there should be an error message. ...


One reason the issue of the type of valid_range keeps coming up is
byte data type and the question of how to represent whether bytes are
to be interpreted as signed or unsigned data.  An exception in the
case of bytes is specifically allowed in the Users Guide documentation
for valid_range:

    ... The type of each valid_range, valid_min and valid_max
    attribute should match the type of its variable (except that for
    byte data, these can be of a signed integral type to specify the
    intended range).

The problem is that you can't have valid_range be of the same type as
the variable (byte), because then it won't be able to represent values
in the entire range from the minimum signed byte (-128) to the
maximum unsigned byte (255), needed to represent whether the values
are intended to be interpreted as signed or unsigned.

--Russ