В этом примере показано, как создать две различных карты распределения памяти, и затем читать из каждой из карт с помощью соответствующего синтаксиса. Затем это показывает, как изменить свойства карты и анализировать ваши данные.
Можно считать содержимое файла, который вы сопоставили с памятью с помощью тех же команд MATLAB®, которые вы используете, чтобы считать переменные из рабочего пространства MATLAB. Путем доступа к Data свойство карты распределения памяти, содержимое отображаемого файла появляется как массив в в настоящее время активной рабочей области. Чтобы считать данные, вы хотите от файла, просто индексируете в массив. Для лучшей производительности скопируйте Data поле к переменной, и затем считало отображаемый файл с помощью этой переменной:
dataRef = m.Data;
for k = 1 : N
y(k) = dataRef(k);
end
В отличие от этого, читая непосредственно из memmapfile объект медленнее:
for k = 1 : N
y(k) = m.Data(k);
end
Во-первых, создайте файл с именем выборочных данных records.dat это содержит 5000 1 матрица чисел с плавающей запятой с двойной точностью.
randData = gallery('uniformdata',[5000,1],0); fileID = fopen('records.dat','w'); fwrite(fileID,randData,'double'); fclose(fileID);
Карта 100 числа с плавающей запятой с двойной точностью от файла до памяти, и затем считала фрагмент сопоставленных данных. Создайте карту распределения памяти, m. Задайте Offset значение 1 024, чтобы начать карту 1 024 байта с запуска файла. Задайте Repeat значение 100 к значениям карты 100.
m = memmapfile('records.dat','Format','double', ... 'Offset',1024,'Repeat',100);
Скопируйте Data свойство к переменной, d. Затем покажите формат d.
d = m.Data;
whos dName Size Bytes Class Attributes d 100x1 800 double
Сопоставленные данные являются 800 массивами байтов, потому что существует 100 double значения, каждое требование 8 байтов.
Считайте выбранное значение чисел из файла путем индексации в вектор, d.
d(15:20)
ans = 6×1
0.8392
0.6288
0.1338
0.2071
0.6072
0.6299
Сопоставьте фрагменты данных в файле, records.dat, как последовательность нескольких типов данных.
Вызовите memmapfile функция, чтобы создать карту распределения памяти, m.
m = memmapfile('records.dat', ... 'Format', { ... 'uint16' [5 8] 'x'; ... 'double' [4 5] 'y' });
Format параметр говорит memmapfile обрабатывать первые 80 байтов файла как 5 8 матрица uint16 значения, и 160 байтов после этого как 4 5 матрица double значения. Этот шаблон повторения до конца файла достигнут.
Скопируйте Data свойство к переменной, d.
d = m.Data
d=166×1 struct array with fields:
x
y
d массив структур с 166 элементами с двумя полями. d нескалярный массив структур, потому что файл сопоставлен как повторяющаяся последовательность нескольких типов данных.
Исследуйте одну структуру в массиве, чтобы показать формат каждого поля.
d(3)
ans = struct with fields:
x: [5x8 uint16]
y: [4x5 double]
Считайте x поле той структуры из файла.
d(3).x
ans = 5x8 uint16 matrix
19972 47529 19145 16356 46507 47978 35550 16341
60686 51944 16362 58647 35418 58072 16338 62509
51075 16364 54226 34395 8341 16341 33787 57669
16351 35598 6686 11480 16357 28709 36239 5932
44292 15577 41755 16362 30311 31712 54813 16353
MATLAB форматирует блок данных как 5 8 матрица uint16 значения, как задано Format свойство.
Считайте y поле той структуры из файла.
d(3).y
ans = 4×5
0.7271 0.3704 0.6946 0.5226 0.2714
0.3093 0.7027 0.6213 0.8801 0.2523
0.8385 0.5466 0.7948 0.1730 0.8757
0.5681 0.4449 0.9568 0.9797 0.7373
MATLAB форматирует блок данных как 4 5 матрица double значения.
Эта часть примера показывает, как построить преобразование Фурье данных, считанных из файла с помощью карты распределения памяти. Это затем изменяет несколько свойств существующей карты, читает из другой части файла данных и строит гистограмму из тех данных.
Создайте файл примера под названием double.dat.
randData = gallery('uniformdata',[5000,1],0); fileID = fopen('double.dat','w'); fwrite(fileID,randData,'double'); fclose(fileID);
Создайте memmapfile object из 1 000 элементов типа double, запуск на уровне 1025-го байта.
m = memmapfile('double.dat','Offset',1024, ... 'Format','double','Repeat',1000);
Скопируйте Data свойство к переменной, k. Затем сопоставьте данные с картой и постройте БПФ первых 100 значений карты.
k = m.Data; plot(abs(fft(k(1:100))))

Это - первый раз, когда на данные ссылаются и - когда фактическое отображение файла к адресному пространству MATLAB происходит.
Измените свойства карты, но продолжите использовать тот же файл. Каждый раз, когда вы изменяете значение свойства карты распределения памяти, MATLAB повторно сопоставляет файл с памятью.
m.Offset = 4096;
m.Format = 'single';
m.Repeat = 800;m теперь memmapfile объект 800 элементов типа single. Карта теперь начинается на уровне 4096-го байта в файле, records.dat.
Читайте из фрагмента файла, который начинается на уровне 4096-го байта, и вычислите максимальное значение данных. Эта команда сопоставляет новую область и не сопоставляет предыдущую область.
X = max(m.Data)
X = single
7.5449e+37