Next: nc_rename_dim, Previous: nc_inq_dimid, Up: Dimensions
This family of functions returns information about a netCDF dimension. Information about a dimension includes its name and its length. The length for the unlimited dimension, if any, is the number of records written so far.
The functions in this family include nc_inq_dim, nc_inq_dimname, and nc_inq_dimlen. The function nc_inq_dim returns all the information about a dimension; the other functions each return just one item of information.
int nc_inq_dim (int ncid, int dimid, char* name, size_t* lengthp); int nc_inq_dimname (int ncid, int dimid, char *name); int nc_inq_dimlen (int ncid, int dimid, size_t *lengthp);
ncid
dimid
name
lengthp
These functions return the value NC_NOERR if no errors occurred. Otherwise, the returned status indicates an error. Possible causes of errors include:
Here is an example using nc_inq_dim to determine the length of a dimension named lat, and the name and current maximum length of the unlimited dimension for an existing netCDF dataset named foo.nc:
#include <netcdf.h> ... int status, ncid, latid, recid; size_t latlength, recs; char recname[NC_MAX_NAME+1]; ... status = nc_open("foo.nc", NC_NOWRITE, &ncid); /* open for reading */ if (status != NC_NOERR) handle_error(status); status = nc_inq_unlimdim(ncid, &recid); /* get ID of unlimited dimension */ if (status != NC_NOERR) handle_error(status); ... status = nc_inq_dimid(ncid, "lat", &latid); /* get ID for lat dimension */ if (status != NC_NOERR) handle_error(status); status = nc_inq_dimlen(ncid, latid, &latlength); /* get lat length */ if (status != NC_NOERR) handle_error(status); /* get unlimited dimension name and current length */ status = nc_inq_dim(ncid, recid, recname, &recs); if (status != NC_NOERR) handle_error(status);