Подтвердить что ты не робот

Загрузите базу данных ЭКГ MIT-BIH на MATLAB

Я работаю над обработкой сигналов ЭКГ с использованием нейронной сети, которая включает распознавание образов. Поскольку мне нужно собрать все данные из Matlab, чтобы использовать их в качестве тестового сигнала, мне трудно загрузить его в Matlab. Я использую базу данных аритмии MIT здесь.

Сигнал необходимо индексировать и хранить в виде структуры данных в формате Matlab. В настоящее время сигнал находится в формате .atr и .dat.

Как вы можете загрузить базу данных MIT-BIH Arrhythmia на Matlab?

4b9b3361

Ответ 1

Вы можете использовать physionet ATM, чтобы получить файлы .mat, с которыми легче работать.

Во входной части выберите нужные провода, длину, базу данных и образец.

В панели инструментов выберите export as .mat:

enter image description here

Затем загрузите файл .mat,

enter image description here

Чтобы открыть файл в MATLAB, вот пример кода:

load ('100m.mat')          % the signal will be loaded to "val" matrix
val = (val - 1024)/200;    % you have to remove "base" and "gain"
ECGsignal = val(1,1:1000); % select the lead (Lead I)
Fs = 360;                  % sampling frequecy
t = (0:length(ECGsignal)-1)/Fs;  % time
plot(t,ECGsignal)

и вы получите

enter image description here

Однако, если бы вы читали файлы аннотаций для аритмий или QRS-комплексов, это было бы еще одной проблемой.

Edit

База и усиление поступают из информационного файла (второе изображение). Этот файл предоставляет вам различную информацию о сигнале ЭКГ.

enter image description here

В последнем предложении говорится: "Чтобы преобразовать из необработанных единиц в физические единицы, показанные выше, вычтите" базу "и разделите на" коэффициент усиления ".

Ответ 2

Вам нужна программа rddata.m (MATLab script) из этого веб-сайта. Здесь вы можете найти здесь. rddata.m, вероятно, единственная программа, которая вам понадобится для чтения сигналов ecg. Я помню, что я использовал эту программу и базу данных не так давно.

Ответ 3

Итак, я прочитал этот ответ 3 месяца назад и удалил базу и получил. Оказывается, я полностью переместил свои R-пики в разные стороны, забив все мои результаты. Хотя я не уверен, что делать это необходимо в Matlab или нет, НЕ ДЕЛАЙТЕ ЭТО, если вы не препроцитируете свой сигнал в Matlab. Я был preprocessing мой сигнал в python, и все, что я сделал для normalizae это было

val = val/2047  % (2047 is the max volt range of signals)

и использовали фильтры масляного фильтра для удаления артефактов (диапазон 0.5hz-45hz)

КОРРЕКЦИЯ

Вырезание я выбрано от 0,5 до 45 не 5-15, как я ранее сообщал. Эта отсечка сохраняет QRS для различных аритмий, не добавляя слишком много шума.

# baseline correction and bandpass filter of signals 
lowpass = scipy.signal.butter(1, highfreq/(rate/2.0), 'low') 
highpass = scipy.signal.butter(1, lowfreq/(rate/2.0), 'high') 

# TODO: Could use an actual bandpass filter 
ecg_low = scipy.signal.filtfilt(*lowpass, x=ecg) 
ecg_band = scipy.signal.filtfilt(*highpass, x=ecg_low)

Ответ 4

Используйте ATM, чтобы извлечь .mat, как описано Kamtal ( теперь известный Рашид). Однако обратите внимание, что для просмотра файла .info в некоторых случаях вам нужно щелкнуть стрелку

enter image description here

После того, как я переместил это вперед разработчикам здесь, мы получили улучшения в документации здесь в разделе 4.

Если они все целые числа в диапазоне [-2 ^ N, 2 ^ N-1] или [0, 2 ^ N], они, вероятно, являются цифровыми. Сравните значения, чтобы узнать, находятся ли они в ожидаемом физиологическом диапазоне сигнала, который вы анализируете. Например, если в заголовке указано, что сигнал является ЭКГ, хранящимся в миливольтах, который обычно имеет амплитуду около 2 мВ, сигнал целых чисел в диапазоне от -32000 до 32000, вероятно, не дает вам физическую ЭКГ в milivolts...

Если они не являются целыми числами, они являются физическими. Еще раз вы можете быстро сравнить значения, чтобы узнать, находятся ли они в ожидаемом физиологическом диапазоне сигнала, который вы анализируете.

0-9-10 wfdb - физические единицы

Мы говорим, что сигналы находятся в "физических единицах", когда значения используются для представления фактических значений реальной жизни как можно ближе, хотя очевидно, что все на компьютере является цифровым и дискретным, а не аналоговым и непрерывным. Это включает в себя наши драгоценные 64-битные значения двойной точности с плавающей запятой, но это так близко, что мы можем получить и уже очень близко к фактическим физическим значениям, поэтому мы называем их "физическими".

-

Например, если 15-битовый сигнал собран через устройство захвата, Physionet, скорее всего, сохранит его как 16-битный сигнал. Каждый 16-разрядный блок сохраняет целое значение между -2 ^ 15 и 2 ^ 15-1, и с использованием коэффициента усиления и смещения, указанного в заголовке для каждого канала, исходный физический сигнал может быть отображен для обработки.

Единицы по умолчанию теперь являются физическими единицами, где база и усиление должны быть добавлены в заголовке для каждого канала, поэтому физический сигнал может быть отображен для обработки.

% rawUnits
%       A 1x1 integer (default: 0). Returns tm and signal as vectors
%       according to the following values:
%               rawUnits=0 - Uses Java Native Interface to directly fetch  data, returning signal in physical units with double precision.
%               rawUnits=1 -returns tm ( millisecond precision only! ) and signal in physical units with 64 bit (double) floating point precision
%               rawUnits=2 -returns tm ( millisecond precision only! ) and signal in physical units with 32 bit (single) floating point  precision
%               rawUnits=3 -returns both tm and signal as 16 bit integers (short). Use Fs to convert tm to seconds.
%               rawUnits=4 -returns both tm and signal as 64 bit integers (long). Use Fs to convert tm to seconds.

rawUnits=1, rawUnits=2 используют также физические единицы. rawUnits=3, rawUnits=4 снова использовать аналого-цифровые единицы, где вам нужно удалить базу и усилить. Если вы используете rawUnits=1 или rawUnits=2, вам нужно настроить для базы и усиления, где base = 1024 и gain = 200

# Kamtal method in considering base and gain
load('201m.mat');
val = (val - 1024)/200;    % you have to remove "base" and "gain"
ECGsignal = val(1,16:950); % select the lead (Lead I)

Смотрите файл .info ниже, где вы можете получить base и gain. Существует также единица mV, которая предполагает, что значения должны быть близки к 2 после операций с базовым коэффициентом усиления.

< 0-9-9 wfdb - аналоговые/цифровые устройства, поэтому база и коэффициент усиления по умолчанию; теперь только rawUnits=3,4 для аналоговых блоков

После выбора ATM вы сможете увидеть список, в котором вы можете выбрать файл .info после экспорта, как описано в ответе Kamtal. Файл .info указывает, чтобы перед использованием использовать так называемую базу и коэффициент усиления.

Source: record mitdb/201  Start: [00:02:10.000]
val has 2 rows (signals) and 3600 columns (samples/signal)
Duration:     0:10
Sampling frequency: 360 Hz  Sampling interval: 0.002777777778 sec
Row     Signal  Gain    Base    Units
1       MLII    200     1024    mV
2       V1      200     1024    mV

To convert from raw units to the physical units shown
above, subtract 'base' and divide by 'gain'.

Сравнение неправильных ответов здесь! [Устаревшие]

Калмал (теперь называемый Рашидом) отвечает о старой системе wfdb, которая использовала цифровые устройства без удаления базы и усиления

# Kamtal method in considering base and gain
load('201m.mat');
val = (val - 1024)/200;    % you have to remove "base" and "gain"
ECGsignal = val(1,16:950); % select the lead (Lead I)

# Method without considering base and gain
load('201m.mat');
ECGsignal2 = val(1,16:950); 

# http://www.mathworks.com/matlabcentral/fileexchange/10502-image-overlay
imshow(imoverlay(ECGsignal, ECGsignal2, uint8([255,0,0])))

и вы получите разницу между моим методом и его методом

enter image description here

Ответ 5

Существует учебник по использованию Matlab для чтения данных. учебник для пользователя Matlab

  • установите "WFDB Toolbox для Matlab" по ссылке выше. Добавьте папку инструментария в путь в Matlab.

  • Загрузите сигнал ЭКГ. Обязательно загрузите '.atr', '.dat' and '.hea' вместе для сигнала, с которым вы должны иметь дело.

  • Команда в Matlab выглядит следующим образом: [tm,signal,Fs]=rdsamp( filename , 1 ) ; [ann,type]=rdann( filename , 'atr' ) ; Примечание: для сигнала "101" его имя равно "101". И вы можете проверить подробную информацию о rdsamp и rdann из учебника.

Ответ 6

просто используйте его

A=input('Enter Variable: ','s');
load(A);
a=(val(1,:));
b=fir1(100,[0.1,0.25],'stop');
y2=filter(b,1,a);
figure;
plot(y2);