В этом примере показано, как создать две различных карты распределения памяти, и затем читать из каждой из карт с помощью соответствующего синтаксиса. Затем это показывает, как изменить свойства карты и анализировать ваши данные.
Можно считать содержимое файла, который вы сопоставили с памятью с помощью тех же команд 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 d
Name 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