File: coards_conventions.dat

package info (click to toggle)
ferret-vis 6.9-2
  • links: PTS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 236,276 kB
  • ctags: 21,705
  • sloc: fortran: 203,172; ansic: 52,976; csh: 2,913; java: 1,755; makefile: 1,461; sh: 1,435; pascal: 571; sed: 184; lisp: 122; awk: 26
file content (389 lines) | stat: -rw-r--r-- 17,036 bytes parent folder | download | duplicates (7)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
ftp://ftp.unidata.ucar.edu/pub/netcdf/Conventions/COARDS/coards_conventions

Conventions for the standardization of NetCDF files
---------------------------------------------------

Sponsored by the "Cooperative Ocean-Atmosphere Research Data Service"
(COARDS), a NOAA/university cooperative for the sharing and
distribution of global atmospheric and oceanographic research data
sets.

Document revision history:

10 February 1995 - version 1.0
13 March 1995 - minor editorial repairs
24 April 1995 - reformatted with slight modifications for Unidata
		conventions FTP site  (KRS)



University participants:

   CIRES (University of Colorado Joint Institute, Boulder CO)
   JISAO (University of Washington Joint Institute, Seattle WA)

NOAA participants:

   NCDC, Asheville NC  (GCPS project)
   CDC, Boulder CO
   PMEL, Seattle WA


For more information, contact:

   Steve Hankin, hankin@pmel.noaa.gov,  or
   Keith Searight, ksearight@cdc.noaa.gov

----------------------------------------------------------------------

Relationship to other Standards:

This standard is a set of conventions adopted in order to promote the
interchange and sharing of files created with the netCDF Application
Programmer Interface (API). This standard is based upon version 2.3 of
netCDF. Documentation of the netCDF API may be found in the "NetCDF
Users' Guide, Version 2.3, April 1993 available from URL
http://www.unidata.ucar.edu/packages/netcdf/ or via anonymous ftp at
ftp.unidata.ucar.edu. All conventions named in that document will be
adhered to in this standard unless noted to the contrary.

This standard also refers to version 1.7.1 of the udunits standard
supported by Unidata. The udunits package is available via anonymous
ftp at ftp.unidata.ucar.edu. Included in the udunits package is a
file, udunits.dat, which lists collections of unit names. The names
given therein and their plural forms will be regarded as acceptable
unit names for this standard with the following additions and
deletions:

   "degrees" - deleted 
   "level", "layer", "sigma_level" - added 

The unit "degrees" creates ambiguities when attempting to
differentiate longitude and latitude coordinate variables; files must
use "degrees_east" for units of longitude and "degrees_north" for
units of latitude or the alternative "spellings" of those names listed
in the sections on longitude and latitude coordinates below. The
dimensionless units "level", "layer", and "sigma_level" are sometimes
needed when representing numerical model outputs.

The udunits package also supports linear transformation of all units
through the syntax "scale_factor unit_name@offset", for example,
"0.0005 degC@40000". This syntax, however, is not supported by this
standard.

These conventions have been registered with Unidata as the COARDS conventions 
and are available at ftp://ftp.unidata.ucar.edu/pub/netcdf/Conventions/COARDS.

Conventions:

File Name:
NetCDF files should have the file name extension ".nc". 

Coordinate Variables: 

1-dimensional netCDF variables whose dimension names are identical to
their variable names are regarded as "coordinate variables" (axes of
the underlying grid structure of other variables defined on this
dimension).

Global attributes: 

Although not mandatory the attribute "history" is recommended to
record the evolution of the data contained within a netCDF
file. Applications which process netCDF data can append their
information to the history attribute.

The optional attribute "Conventions" is recommended to reference the COARDS
conventions, registered with Unidata, and available via ftp at 

   directory:      pub/netcdf/Conventions/COARDS
   host:           ftp.unidata.ucar.edu

The attribute has this value:

  :Conventions = "COARDS";
  // Cooperative Ocean/Atmosphere Research Data Service

Data Variable attributes:

   long_name - a long descriptive name (title). This could be used for
labelling plots, for example. If a variable has no long_name attribute
assigned, the variable name will be used as a default.

   scale_factor - If present for a variable, the data are to be
multiplied by this factor after the data are read by the application
that accesses the data. (see further discussion under the add_offset
attribute)

   add_offset - If present for a variable, this number is to be added
to the data after it is read by the application that accesses the
data. If both scale_factor and add_offset attributes are present, the
data are first scaled before the offset is added. The attributes
scale_factor and add_offset can be used together to provide simple
data compression to store low-resolution floating-point data as small
integers in a netCDF file. When scaled data are written, the
application should first subtract the offset and then divide by the
scale factor.  The NOAA cooperative standard is more restrictive than
the netCDF Users Guide with respect to the use of the scale_factor and
add_offset attributes; ambiguities and precision problems related to
data type conversions are resolved by these restrictions. If the
scale_factor and add_offset attributes are of the same data type as
the associated variable no restrictions apply; the unpacked data is
assumed to be of the same data type as the packed data. However, if
the scale_factor and add_offset attributes are of a different data
type than the associated variable (containing the packed data) then in
files adhering to this standard the associated variable may only be of
type byte, short, or long. The attributes scale_factor and add_offset
(which must match in data type) must be of type float or double. The
data type of the attributes should match the intended type of the
unpacked data. (It is not advised to unpack a long into a float as
there is a potential precision loss.)

   _FillValue - If a scalar attribute with this name is defined for a
variable and is of the same type as the variable, it will be
subsequently used as the fill value for that variable. The purpose of
this attribute is to save the applications programmer the work of
prefilling the data and also to eliminate the duplicate writes that
result from netCDF filling in missing data with its default fill
value, only to be immediately overwritten by the programmer's
preferred value. This value is considered to be a special value that
indicates missing data, and is returned when reading values that were
not written.  The missing value should be outside the range specified
by valid_range (if used) for a variable. It is not necessary to define
your own _FillValue attribute for a variable if the default fill value
for the type of the variable is adequate.

   missing_value - missing_value is a conventional name for a missing
value that will not be treated in any special way by the library, as
the _FillValue attribute is. It is also useful when it is necessary to
distinguish between two kinds of missing values. The netCDF data type
of the missing_value attribute should match the netCDF data type of
the data variable that it describes. In cases where the data variable
is packed via the scale_value attribute this implies that the
missing_value flag is likewise packed. The same holds for the
_FillValue attribute. The NOAA cooperative standard does not endorse
any particular interpretation of the distinction between missing_value
and _FillValue.

Units attribute:

A character array that specifies the units used for the variable's
data. Where possible the units attribute should be formatted as per
the recommendations in the Unidata udunits package.

Other attributes: 

A file will normally contain many attributes that are not standardized
in this profile. Those attributes do not represent a violation of this
standard in any way. Application programs should ignore attributes
that they do not recognize.

Variable names:

Variable names should begin with a letter and be composed of letters,
digits, and underscores. It is recommended that variable names be
case-insensitive implying that the same case-insensitive name should
not be used for multiple variables within a single file.

Rectilinear coordinate systems, only:

The space/time locations of points within the netCDF variables should
be the simple ordered tuples formed by associating values from their
coordinate axes. Thus, for example, curvilinear coordinate systems in
which the coordinate locations must be inferred from other
non-coordinate variables or from an equation are not standardized by
this netCDF profile.

Number of dimensions:

All netCDF variables will be defined on either one, two ,three, or
four dimensions (the nature of the data will dictate the natural
encoding). Where it makes sense single point locations should be
encoded as coordinate variables, for example, the latitude and
longitude positions of a vertical profile are natural candidates for
single point latitude and longitude coordinate variables.  If it is
necessary to create a netCDF file with more than 4 dimensions it is
recommended that the additional dimension(s) be added "to the left" of
the space and time dimensions as represented in CDL. For example

        float my_variable(param_value,time,height,lat,lon);  

would be the recommended representation of a fifth, parameter value,
coordinate.

Coordinate variable names:

The names of coordinate variables are not standardized by these
conventions (since data sets may in general contain multiple
coordinate variables of the same orientation). Coordinate variable
names should follow the same general naming rules (above) as other
netCDF variables.

Order of dimensions:

If any or all of the dimensions of a variable have the interpretations
of "date or time" (a.k.a. "T"), "height or depth" (a.k.a. "Z"),
"latitude" (a.k.a. "Y"), or "longitude" (a.k.a. "X") then those
dimensions should appear in the relative order T, then Z, then Y, then
X in the CDL definition corresponding to the file.

Data type:

The data type of coordinate and non-coordinate variables is
unrestricted (byte, short, long, float, and double are all acceptable
data types). Although not forbidden by this standard the data type
"char", which is functionally identical to "byte", is not recommended
as netCDF has reserved the option to modify its behavior in future
versions.

Coordinate value ordering:

The coordinate values of a coordinate variable must be either
monotonically increasing or monotonically decreasing. However, the
coordinate values need not be evenly spaced. Missing values are not
permitted in coordinate variables.

Coordinate Variable Attributes:

If a coordinate variable contains longitude, latitude, depth,
elevation, date, or time values then the units attribute is mandatory;
it is used to determine the orientation of the coordinate
variable. The long_name attribute is optional but may be used to
enhance clarity and the self-describing nature of the netCDF file.
Since coordinate variables may not contain missing values the
attributes _FillValue and missing_value may not be used with
coordinate variables.

Time or date dimension:

Coordinate variables representing time must always explicitly include
the units attribute; there is no default value. A time coordinate
variable will be identifiable by its units, alone. The units attribute
will be of character type with the string formatted as per the
recommendations in the Unidata udunits package version 1.7.1. The
following excerpt from the udunits documentation explains the time
unit encoding by example:

The specification:

seconds since 1992-10-8 15:15:42.5 -6:00

indicates seconds since October 8th, 1992 at 3 hours, 15 minutes and
42.5 seconds in the afternoon in the time zone which is six hours to
the west of Coordinated Universal Time (i.e. Mountain Daylight Time).
The time zone specification can also be written without a colon using
one or two-digits (indicating hours) or three or four digits
(indicating hours and minutes).

The acceptable units for time are listed in the file udunits.dat. The
most commonly used of these strings (and their abbreviations) includes
day (d), hour (hr, h), minute (min), second (sec, s), year
(yr). Plural forms are also acceptable. The date string may include
date alone; date and time; or date, time, and time zone.  It is
recommended that the unit "year" not be used as a unit of time. Year
is an ambiguous unit as years are of varying length. Udunits defines a
year as exactly 365 days.

A time coordinate variable is identifiable from its units string,
alone. The udunits routines utScan and utIsTime can be used to make
this determination. (*Note that at the time of this writing the author
of this draft profile had not tested these routines personally.)

Climatological time:

Coordinate variables representing climatological time (an axis of 12
months, 4 seasons, etc. that is located in no particular year) should
be encoded like other time axes but with the added restriction that
they be encoded to begin in the year 0000. (Note - at the time of this
writing this encoding has not been tested with the udunits package.)

Vertical (height or depth) dimension:

Coordinate variables representing height or depth must always
explicitly include the units attribute; there is no default value for
the units attribute. The units attribute will be of character type.

The acceptable units for vertical (depth or height) coordinate
variables are:

   - units of pressure as listed in the file udunits.dat. For vertical
axes the most commonly used of these include include bar, millibar,
decibar, and atmosphere (atm).
   - units of length as listed in the file udunits.dat. For vertical
axes the most commonly used of these include meter (metre, m),
centimeter (cm), decimeter (dm), and feet (ft).
   - the (dimensionless) units "level", "layer", or "sigma_level"
   - other units listed in the file udunits.dat that may under certain
circumstances reference vertical position such as units of density or
temperature.

Plural forms are also acceptable.

The direction of positive, whether up or down, cannot in all cases be
inferred from the units. The direction of positive is useful for
applications displaying the data. For this reason the new attribute
positive is defined in this standard. The inclusion of the positive
attribute is required by this standard if the vertical axis units are
not a valid unit of pressure (a determination which can be made using
the udunits routine, utScan) -- otherwise its inclusion is
optional. The positive attribute may have the value "up" or "down"
(case insensitive).

For example, if an oceanographic netCDF file encodes the depth of the
surface as 0 and the depth of 1000 meters as 1000 then the axis would
use attributes as follows:

axis_name:units="meters"; 
axis_name:positive="down"; 

If, on the other hand, the depth of 1000 meters were represented as
-1000 then the value of the positive attribute would have been
"up". If the units attribute value is a valid pressure unit the
default value of the positive attribute is "down".

A vertical coordinate variable will be identifiable by
   - units of pressure; or 
   - the presence of the positive attribute with a value of "up" or
"down" (case insensitive).

Latitude dimension:

Coordinate variables representing latitudes must always explicitly
include the units attribute; there is no default value for the units
attribute. The units attribute will be of character type with the
string formatted as per the recommendations in the Unidata udunits
package.

The recommended unit of latitude is "degrees_north". Also acceptable
are "degree_north", "degree_N", and "degrees_N".

A latitude coordinate variable is identifiable from its units string,
alone. The udunits routines utScan can be used to make this
determination. (Note that at the time of this writing the author of
this draft profile had not tested these routines personally.)

Longitude dimension:

Coordinate variables representing longitudes must always explicitly
include the units attribute; there is no default value for the units
attribute. The units attribute will be of character type with the
string formatted as per the recommendations in the Unidata udunits
package.

The recommended unit of longitude is "degrees_east" (eastward
positive). Also acceptable are "degree_east", "degree_E", and
"degrees_E". The unit "degrees_west" (westward positive) is not
recommended because it implies a negative conversion factor from
degrees_east.

Longitudes may be represented modulo 360. Thus, for example, -180,
180, and 540 are all valid representations of the International
Dateline and 0 and 360 are both valid representations of the Prime
Meridian. Note, however, that the sequence of numerical longitude
values stored in the netCDF file must be monotonic in a non-modulo
sense.

A longitude coordinate variable is identifiable from its units string,
alone. The udunits routines utScan can be used to make this
determination. (Note that at the time of this writing the author of
this draft profile had not tested these routines personally.)