Preprocessing of ECGs for classification of ventricular arrhythmia
    6 views (last 30 days)
  
       Show older comments
    
I have coded preprocessing mentioned in this research paper . Is my preprocessing code correct? Am I going in right direction?
Please bother to run my code on random recordings of NSR, CU Ventricular Tacharrhythmia, MIT BIH SupraVentricular Arrhythmia and MIT BIH Malignant Ventricular Ectopy. These recording are available to download from PhysioNet ECG Data-set. I am referring external link because data-set is more than 5MB.
If code is correct and I am going in right direction, how should I proceed?
Should I concatenate 500 milli sec windows of signals and start Feature Extraction?
My pre-processioning code is named as code5.m By default sampling frequency of NSR and Supraventricular ECGs is 128 Hz and for others it's 250 Hz.
2 Comments
  Star Strider
      
      
 on 1 Feb 2016
				I do not access files on sites external to MathWorks (for MATLAB Answers posts). Please upload all of them here using the ‘paperclip’ icon, and be sure to complete both the ‘Choose file’ and ‘Attach file’ steps.
Accepted Answer
  Star Strider
      
      
 on 2 Feb 2016
        I would not use the Symbolic Math Toolbox at all for signal processing, unless it involved a one-off derivation that I would then transform to a numeric calculation.
Here:
[q, r] = quorem(sym(nu), sym(ss)) ;% quotient
you apparently want to divide the length of the signal by 4*Fs and get the quotient and remainder. It’s much faster to do this numerically:
q = fix(nu/ss);
r = rem(nu,ss);
Here:
for k= 1:size(splitedParts,2);
    y_nsr16265(:,k)= filtfilt(b,a,splitedParts (:,k) ) ; 
end
I would filter the entire signal first, then split it. That reduces the effect of end transients that can be part of any filtering procedure. I would also use the second-order-section (‘sos,g’) implementation for stability, rather than using the transfer function coefficients.
Beyond that, while I do not agree with the preprocessing procedure in the paper (and the reason I advised you to do it differently), your code looks acceptable. You need to test it to see if it produces the results you want, and change it if it does not.
8 Comments
More Answers (0)
See Also
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!

