---------------------------------------------
RubyNetCDF is the Ruby interface of the NetCDF library. Ruby is a free object-oriented scripting language and is freely available from the Ruby homepage. To handle numeric data, RubyNetCDF uses NArray, which is the standard numeric multi-dimensional array class for Ruby. Thus, you have to have installed it before installing this library. An NArray object holds numeric data in a consecutive memory area pointed by a C pointer. Thus, it is computationally efficient. NArray is similar to NumPy for Python, but results of some benchmark tests suggests that NArray is more efficient than NumPy. Optionally, RubyNetCDF offers methods to handle data missing automatically. To use it, you will also need NArrayMiss. See Usage for details.
RubyNetCDF consists of the four classes in the following.
class NetCDF -- the file class
An NetCDF object represents a NetCDF file
class NetCDFDim -- the dimension class
Although in its C version a NetCDF dimension is represented by a combination of a file ID and a dimension ID, it is represented by only one NetCDFDim object in RubyNetCDF.
class NetCDFVar -- the variable class
Although in its C version a NetCDF variable is represented by a combination of a file ID and a variable ID, it is represented by only one NetCDFVar object in RubyNetCDF.
class NetCDFAtt -- the attribute class
Although in its C version a NetCDF attribute is represented by a combination of file ID, variable ID, and its name, it is represented by only one NetCDFAtt object in RubyNetCDF.
All the NetCDF variable types char, byte, short, int, float, and double are supported in this Ruby interface. These types are called, however, differently in it to adhere to the convention of Ruby, or, more specifically, of NArray. These types are named to as "char", "byte", "sint", "int", "sfloat", and "float", respectively. Therefore, the vartype (=ntype) method of the NetCDFVar class returns one of these strings. The def_var method of the NetCDF class also accepts one of them to define a variable. It should be noted especially that "float" in this library means the double in the NetCDF terminology. This is due to the convention of Ruby -- the predefined Float class corresponds to the double in C, not the float.
The "get" method of NetCDFVar class reads a variable in a NArray of the same type as in the file, except for the "char" type which is read into a "byte". This is because NArray does not have a "char" type. However, it not is not supposed to be a problem, since a byte NArray can easily handle string data.
Errors are basically handled by raising exceptions. However, light errors in value-returning methods are handled by returning nil (e.g., if a non-existent attribute name is specified in attribute reading). Those methods that return nil on error are explicitly written as such in the following.
Security handling is done just as in the pre-defined File class.
To use the RubyNetCDF library, load the library first by placing the following line in your Ruby program to load the library:
require 'numru/netcdf'
If you want to use automatic data-missing-handling methods (of NetCDFVar class), use the following:
require 'numru/netcdf_miss'
This will call require 'numru/netcdf' inside at the beginning, so 
you do not have to call the both. The missing-data handling is done 
with NArrayMiss,
so you have have installed it. This is, however, not needed if you only
call require 'numru/netcdf'.
Here, 'numru', which stands for "Numerical Ruby", is the name of the subdirectory in the user's load path where the RubyNetCDF library is placed. Then, it can be used as in the following:
file = NumRu::NetCDF.create('tmp.nc')
x = file.def_dim('x',10)
y = file.def_dim('y',10)
v = file.def_var('v','float',[x,y])
file.close
Here, NumRu is the module that has the library in it. The reason why NetCDF library is wrapped in such a module is to avoid conflicts in the name space. Without this kind of treatment, problems happen if the user wants to use a library that happens to have a class or module with the same name as even one of the classes in this library.
If such a problem is not expected to happen, the prefix "NumRu::" can be eliminated by "including" the NumRu module as in the following, so that to place "NumRu::" is not needed anymore in the current scope:
include NumRu
file = NetCDF.create('tmp.nc')
...
For more examples, see demo and test programs included in the distribution package.
---------------------------------------------
method_name(argument1, argument2, ...) -- arguments that can be omitted are expressed as Argument_name=Default_valueExplanation of its function
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
---------------------------------------------
Class Methods
Instance Methods
Class Methods
Instance Methods
Class Methods
Instance Methods
Instance Methods added by requiring "numru/netcdf_miss"
Class Methods
Instance Methods
---------------------------------------------
NetCDF.open(filename, mode="r", share=false)Opens a file (class method). If mode="w" and the file does not exist, a new file is created.
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
NetCDF.newAliased to NetCDF.open
NetCDF.create(filename, noclobber=false, share=false)Creates a NetCDF file (class method)
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
NetCDF.create_tmp(tmpdir=ENV['TMPDIR']||ENV['TMP']||ENV['TEMP']||'.', share=false)Creates a temporary NetCDF file (class method). Its name is automatically generated, and it is deleted when closed.
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
closeCloses the file.
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
ndimsReturns the number of dimensions in the file
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
nvarsReturns the number of variables in the file
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
nattsReturns the number of global attributes in the file
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
unlimitedReturns the unlimited dimension in the file
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
pathReturns the path of the file (contents of the filename specified when opened/created)
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
redefSwitches to the define mode. Does nothing if already in it (nil returned).
Arguments
Return value
nil if the file is already in the define mode. Exception is raised if unsuccessful for other reasons.
Corresponding (dependent) function(s) in the C library of NetCDF * nc_redef
enddefSwitches to the data mode. Does nothing if already in it (nil returned).
Arguments
Return value
nil if the file is already in the data mode. Exception is raised if unsuccessful for other reasons.
Corresponding (dependent) function(s) in the C library of NetCDF * nc_enddef
define_mode?Inquire whether the file is in the define mode.
Arguments
Return value
false if the file is in the data mode; nil otherwise (possibly the file is read-only).
Corresponding (dependent) function(s) in the C library of NetCDF * combination of nc_redef and nc_enddef
syncSynchronizes the disk copy of a netCDF dataset with in-memory buffer
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
def_dim(dimension_name, length)Define a dimension
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
put_att(attribute_name, value, atttype=nil)Sets a global attribute
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
def_var(name, vartype, dimensions)Defines a variable
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
def_var_with_dim(name, vartype, shape_ul0, dimnames)Same as def_var but defines dimensions first if needed. Raise exception if it conflicts with the lengths of existing dimensions.
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
var(var_name)Opens an existing variable in the file
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
vars(names)Opens existing variables in the file
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
dim(dimension_name)Opens an existing dimension in the file
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
dims(names)Opens existing dimensions in the file
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
att(attribute_name)Opens an existing global attribute in the file
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
fill=(filemode)Sets a fill mode. (Default behavior of NetCDF is FILL.)
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
each_dim{ ... }Iterator regarding the dimensions in the file. Ex.: {|i| print i.name,"\n"} prints names of all dimensions
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
each_var{ ... }Iterator regarding the variables in the file. Ex.: {|i| print i.name,"\n"} prints names of all variables
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
each_att{ ... }Iterator regarding the global attributes of the file. Ex.: {|i| print i.name,"\n"} prints names of all of them.
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
dim_namesReturns the names of all dimensions in the file
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
var_namesReturns the names of all variables in the file
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
att_namesReturns the names of all the global attributes of the file
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
---------------------------------------------
lengthReturns the length of the dimension
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
length_ul0Same as length but returns 0 for the unlimited dimension
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
name=(dimension_newname)Rename the dimension
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
nameReturns the name of the dimension
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
unlimited?Inquires whether the dimension is unlimited or not
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
---------------------------------------------
NetCDFVar.new(file,varname,mode="r",share=false)open a NetCDF variable. This can also be done with NetCDF#var (instance method of NetCDF class), which is recommended over this method.
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
NetCDFVar.unpack_type=(na_type)Fix the NArray type to be used in unpack.
Arguments
Return value
NetCDFVar.unpack_typeReturns the NArray type set by NetCDFVar.unpack_type=.
Return value
dim(dim_num)Inquires the dim_num-th dimension of the variable (dim_num=0,1,2,..)
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
dimsReturns an array of all the dimensions of the variable
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
shape_ul0Returns the shape of the variable, but the length of the unlimited dimension is set to zero. Good to define another variable.
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
shape_currentReturns the current shape of the variable.
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
each_att{ ... }Iterator regarding the global attributes of the variables. Ex.: {|i| print i.name,"\n"} prints names of all of them.
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
dim_namesReturns the names of all the dimensions of the variable
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
att_namesReturns the names of all the attributes of the variable
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
nameReturns the name of the variable
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
name=(variable_newname)Rename the variable
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
ndimsNumber of dimensions of the variable (which is rank of the variable).
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
rankAliased to ndims
ntypeAliased to vartype
vartypeInquires the data value type of the variable
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
typecodeInquires the data type of the variable (returns a typecode of NArray)
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
nattsReturns the number of the attributes of the variable
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
fileInquires the file that the variable is in
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
att(attribute_name)Returns the attribute specified by its name
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
put_att(attribute_name, value, atttype=nil)Sets an attribute
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
put(value, option=nil)Aliased to simple_put
simple_put(value, option=nil)Set the values of the variable
Arguments
option (Hash) : Optional argument to limit the portion of the variable to output values. If omitted, the whole variable is subject to the output. This argument accepts a Hash whose keys contain either "index" or a combination of "start","end", and "stride". The value of "index" points the index of a scalar portion of the variable. The other case is used to designate a regularly ordered subset, where "start" and "end" specifies bounds in each dimension and "stride" specifies intervals in it. As in Array "start", "end", and "index" can take negative values to specify index backward from the end. However, "stride" has to be positive, so reversing the array must be done afterwards if you like.
Example: If the variable is 2D:
{"start"=>[2,5],"end"=>[6,-1],"stride"=>[2,4]} -- Specifies a subset made as follows: the 1st dimension from the element 2 to the element 6 (note that the count starts with 0, so that the element 2 is the 3rd one) with an interval of 2; the 2nd dimension from the element 6 to the last element (designated by -1) with an interval of 5.
{"index"=>[0,0]}: Scalar of the fist element
{"index"=>[0,-2]}: Scalar from the 1st element of with respect to the 1st dimension and the 2nd element from the last with respect to the 2nd dimension
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
pack(na)Pack a NArray (etc) using the attributes scale_factor and/or add_offset of self.
If scale_factor and/or add_offset is defined, returns (na-add_offset)/scale_factor. Returns na if not.
Arguments
Return value
scaled_put(value, option=nil)Same as simple_put but interprets the attributes scale_factor and/or add_offset using pack.
See the document for simple_put for arguments etc.
get(option=nil)Aliased to simple_get.
simple_get(option=nil)Returns values of the variable
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
unpack(na)Unpack a NArray (etc) using the attributes scale_factor and/or add_offset of self.
If scale_factor and/or add_offset is defined, returns na * scale_factor + add_offset. Returns na if not. Type conversion is made by the coercing -- for example if na is sint and scale_factor and add_offset is sfloat, return value is sfloat. The type of the return value can be specified explicitly with NetCDFVar.unpack_type=.
Arguments
Return value
scaled_get(option=nil)Same as simple_get but interprets the attributes scale_factor and/or add_offset using unpack.
See the document for simple_get for arguments etc.
[]Same as NetCDFVar#get but a subset is specified as in the method [] of NArray.
In addition to the subset specifications supported by NArray, ranges with steps are supported, which is specified like {0..-1, 3}, i.e., a 1-element Hash with the key and value representing the range (Range) and the step (Integer), respectively. Unlike NArray, 1-dimensional indexing of multi-dimensional variables is not support.
[] = Same as NetCDFVar#put but a subset is specified as in the method []= of NArray.
In addition to the subset specifications supported by NArray, ranges with steps are supported, which is specified like {0..-1, 3}, i.e., a 1-element Hash with the key and value representing the range (Range) and the step (Integer), respectively. Unlike NArray, 1-dimensional indexing of multi-dimensional variables is not support.
get_with_miss(option=nil)Same as get but interprets data missing.
Data missing is specified by the standard attributes valid_range, (valid_min and/or valid_max), or missing_value, with the precedence being this order. Unlike the recommendation in the NetCDF User's guide, missing_value is interpreted if present. If missing_value and valid_* present simultaneously, missing_value must be outside the valid range. Otherwise, exception is raised.
If data missing is specified as stated above, this method returns a NArrayMiss. If not, it returns a NArray. Thus, you can use this whether data missing is defined or not.
Arguments
Return value
Possible exception in addition to NetcdfError.
Corresponding (dependent) function(s) in the C library of NetCDF
EXAMPLE
The following is an example to replace get with get_with_miss.
       It will also make [] interpret data missing, 
       since it calls get internally.
file = NetCDF.open('hogehoge.nc')
var = file.var('var')
def var.get(*args); get_with_miss(*args); end
p var.get       # --> interprets data missing if defined
p var[0..-1,0]  # --> interprets data missing if defined (assumed 2D)get_with_miss_and_scaling(option=nil)Same as get_with_miss but handles data scaling too using unpack.
Missing data handling using valid_* / missing_value is applied basically to packed data, which is consistent with most conventions. However, it is applied to unpacked data if and only if the type of valid_* / missing_value is not the same as the packed data and is the samed as the unpacked data. This treatment can handle all conventions.
EXAMPLE
put_with_miss(value, option=nil)Same as put but interprets data missing.
If value is an NArray, the methods behaves as put.
Data missing in value is interpreted if it is an NArrayMiss
and data missing is specified by attributes in self 
(see get_with_miss ).
Namely, the data which are "invalid" in the value is replaced
with a missing value when written in the file.
(missing_value or _FillValue or a value outside
the valid range). No check is made whether "valid" values in the 
NArrayMiss is within the valid range of self.
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
EXAMPLE
The following is an example to replace put with put_with_miss.
       It will also make []= interpret data missing, 
       since it calls put internally.
file = NetCDF.open('hogehoge.nc')
var = file.var('var')
def var.put(*args); put_with_miss(*args); end
var.put = narray_miss      # --> interprets data missing if defined
var[0..-1,0] = narray_miss # --> interprets data missing if defined (assumed 2D)put_with_miss_and_scaling(value, option=nil)Same as put_with_miss but handles data scaling too using pack.
Missing data handling using valid_* / missing_value is applied basically to packed data, which is consistent with most conventions. However, it is applied to unpacked data if and only if the type of valid_* / missing_value is not the same as the packed data and is the samed as the unpacked data. This treatment can handle all conventions.
EXAMPLE
---------------------------------------------
nameReturns the name of the attribute
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
name=(attribute_newname)Rename the attribute
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
copy(var_or_file)Copies an attribute to a variable or a file. If file, becomes an global attribute
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
deleteDelete an attribute
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
put(value, atttype=nil)Sets the value of the attribute
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
getReturns the values of the attribute
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
atttypeInquires the type of attribute values
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF
atttypeInquires the type of attribute values (returns a NArray typecode)
Arguments
Return value
Corresponding (dependent) function(s) in the C library of NetCDF