Export to CDF Files
This example shows how to export data to a CDF file using MATLAB® CDF low-level functions. The MATLAB functions correspond to routines in the CDF C API library.
To use the MATLAB CDF low-level functions effectively, you must be familiar with the CDF C interface. Also, CDF files do not support non-ASCII encoded inputs. Therefore, variable names, attributes names, variable values, and attribute values must have 7-bit ASCII encoding.
Create New CDF File
Create a new CDF file named my_file.cdf using cdflib.create. This function corresponds to the CDF library C API routine CDFcreateCDF. cdflib.create returns a file identifier.
cdfid = cdflib.create("my_file.cdf");Create Variables in CDF File
Create variables named Time and Latitude using cdflib.createVar. This function corresponds to the CDF library C API routine CDFcreatezVar. cdflib.createVar returns a numeric identifier for each variable.
time_id = cdflib.createVar(cdfid,"Time","cdf_int4",1,[],true,[]); lat_id = cdflib.createVar(cdfid,"Latitude","cdf_int2",1,181,true,true);
Create a variable named Image.
dimSizes = [20 10]; image_id = cdflib.createVar(cdfid,"Image","cdf_int4",1, ... dimSizes,true,[true true]);
Write to Variables
Write data to the first and second records of the Time variable. Record numbers are zero-based. The cdflib.putVarRecordData function corresponds to the CDF library C API routine CDFputzVarRecordData.
cdflib.putVarRecordData(cdfid,time_id,0,int32(23)) cdflib.putVarRecordData(cdfid,time_id,1,int32(24))
Write data to the Latitude variable.
data = int16(-90:90);
recspec = [0 1 1];
dimspec = {0 181 1};
cdflib.hyperPutVarData(cdfid,lat_id,recspec,dimspec,data)Write data to the Image variable.
recspec = [0 3 1];
dimspec = {[0 0],[20 10],[1 1]};
data = reshape(int32(0:599),[20 10 3]);
cdflib.hyperPutVarData(cdfid,image_id,recspec,dimspec,data)Write to Global Attribute
Create a global attribute named TITLE using cdflib.createAttr. This function corresponds to the CDF library C API routine CDFcreateAttr. cdflib.createAttr returns a numeric identifier for the attribute. Attribute numbers are zero-based.
titleAttrNum = cdflib.createAttr(cdfid,"TITLE","global_scope");
Write values to entries in the global attribute.
cdflib.putAttrEntry(cdfid,titleAttrNum,0,"CDF_CHAR","cdf Title") cdflib.putAttrEntry(cdfid,titleAttrNum,1,"CDF_CHAR","Author")
Write to Attributes Associated with Variables
Create attributes associated with variables in the CDF file.
fieldAttrNum = cdflib.createAttr(cdfid,"FIELDNUM","variable_scope"); unitsAttrNum = cdflib.createAttr(cdfid,"UNITS","variable_scope");
Write values to attributes of the Time variable.
cdflib.putAttrEntry(cdfid,fieldAttrNum,time_id, ... "CDF_CHAR","Time of observation") cdflib.putAttrEntry(cdfid,unitsAttrNum,time_id, ... "CDF_CHAR","Hours")
Get Information About CDF File
Get information about the file using cdflib.inquire. This function corresponds to the CDF library C API routines CDFinquireCDF and CDFgetNumgAttributes. cdflib.inquire returns a structure that includes information about the data encoding and the number of variables and attributes in the file.
info = cdflib.inquire(cdfid)
info = struct with fields:
encoding: 'IBMPC_ENCODING'
majority: 'ROW_MAJOR'
maxRec: 2
numVars: 3
numvAttrs: 2
numgAttrs: 1
Close CDF File
Close the CDF file using cdflib.close. This function corresponds to the CDF library C API routine CDFcloseCDF. You must close a CDF file to guarantee that all modifications you made since opening the CDF file are written to the file.
cdflib.close(cdfid)
See Also
cdflib.close | cdflib.create | cdflib.createAttr | cdflib.createVar | cdflib.hyperPutVarData | cdflib.putAttrEntry | cdflib.putVarRecordData