В этом примере показано, как использовать низкоуровневые функции для чтения данных из файла CDF. Низкоуровневые функции CDF MATLAB ® соответствуют подпрограммам в библиотеке API CDF C. Для эффективного использования низкоуровневых функций MATLAB CDF необходимо ознакомиться с интерфейсом CDF C.
Откройте образец файла CDF, example.cdf.
cdfid = cdflib.open('example.cdf');Использовать cdflib.inquire для получения информации о количестве переменных в файле, количестве глобальных атрибутов и количестве атрибутов с переменной областью действия.
info = cdflib.inquire(cdfid)
info = struct with fields:
encoding: 'IBMPC_ENCODING'
majority: 'ROW_MAJOR'
maxRec: 23
numVars: 6
numvAttrs: 1
numgAttrs: 3
Использовать cdflib.inqurieVar для получения информации об отдельных переменных в файле. Идентификаторы переменных начинаются с нуля.
info = cdflib.inquireVar(cdfid,0)
info = struct with fields:
name: 'Time'
datatype: 'cdf_epoch'
numElements: 1
dims: []
recVariance: 1
dimVariance: []
info = cdflib.inquireVar(cdfid,1)
info = struct with fields:
name: 'Longitude'
datatype: 'cdf_int1'
numElements: 1
dims: [2 2]
recVariance: 0
dimVariance: [1 0]
Считывайте данные переменной в рабочую область MATLAB. Первая переменная содержит значения времени периода CDF. Низкоуровневый интерфейс возвращает их как double значения.
data_time = cdflib.getVarRecordData(cdfid,0,0)
data_time = 6.3146e+13
Преобразование значения времени в вектор даты.
timeVec = cdflib.epochBreakdown(data_time)
timeVec = 7×1
2001
1
1
0
0
0
0
Определите, какие атрибуты в файле CDF являются глобальными.
info = cdflib.inquireAttr(cdfid,0)
info = struct with fields:
name: 'SampleAttribute'
scope: 'GLOBAL_SCOPE'
maxgEntry: 4
maxEntry: -1
Считывание значения атрибута. Необходимо использовать cdflib.getAttrgEntry для глобальных атрибутов.
value = cdflib.getAttrgEntry(cdfid,0,0)
value = 'This is a sample entry.'
Использовать cdflib.close для закрытия файла CDF.
cdflib.close(cdfid);