Detecting and Quantifying T-Wave Alternans: The PhysioNet/Computing in Cardiology Challenge 2008 1.0.0
(2,380 bytes)
function Align = CheckLeadCorrelations(ecg, Align)
% CheckLeadCorrelations.m
% Author: Alexander Khaustov; alexander dot khaustov at gmail dot com
% Copyright (C) 2008 St.-Petersburg Institute of Cardiological Technics (Incart), www.incart.ru
% This software is released under the terms of the GNU General
% Public License (http://www.gnu.org/copyleft/gpl.html).
%
% After finding fiducial points we only know the validity of beats in the
% lead of alignment; this routine checks beat validity in other leads
global Param
for lead = 1:size(ecg, 2)
if lead == Align.lead
continue;
end;
% checking correlations vs template beat makes us very vulnerable to a
% noise within this particular beat (which is possible in a lead other than alignment
% lead), thus we better check correlations vs average
qs_templ = zeros(1, Align.q2f + Align.f2s + 1)';
if strcmp(Param.Alignment, 'st')
st_templ = zeros(1, Align.st + 1)';
end;
for i = 1:length(Align.fidQRS)
qs_templ = qs_templ + (ecg((Align.fidQRS(i) - Align.q2f):(Align.fidQRS(i) + Align.f2s), lead) - Align.amp(i, lead));
if strcmp(Param.Alignment, 'st')
st_templ = st_templ + (ecg((Align.fid(i) + Align.f2s):(Align.fid(i) + Align.f2s + Align.st), lead) - Align.amp(i, lead));
end;
end;
Align.qs_templ(:, lead) = qs_templ / length(Align.fidQRS);
Align.st_templ(:, lead) = st_templ / length(Align.fidQRS);
for i = 1:length(Align.fid)
qs_ecg = ecg((Align.fidQRS(i) - Align.q2f):(Align.fidQRS(i) + Align.f2s), lead);
a = corrcoef(qs_templ, qs_ecg);
Align.QRScorr(i, lead) = a(1, 2);
if (a(1, 2) < Param.corrQRS)
Align.valid(i, lead) = false;
continue;
end;
if strcmp(Param.Alignment, 'st')
st_ecg = ecg((Align.fid(i) + Align.f2s):(Align.fid(i) + Align.f2s + Align.st), lead);
a = corrcoef(st_templ, st_ecg);
Align.Tcorr(i, lead) = a(1, 2);
if (a(1, 2) < Param.corrT)
Align.valid(i, lead) = false;
continue;
end;
end;
Align.valid(i, lead) = true;
end;
Align.validleads(lead) = (length(find(Align.valid(:, lead))) >= 0.9 * length(Align.fid));
end;
return;