Detecting and Quantifying T-Wave Alternans: The PhysioNet/Computing in Cardiology Challenge 2008 1.0.0

File: <base>/sources/Khaustov/TWAnalyser/twa-mfiles/CheckLeadCorrelations.m (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;