source: prdatasets/arrhythmia.m @ 116

Last change on this file since 116 was 96, checked in by bduin, 10 years ago
File size: 2.5 KB
RevLine 
[94]1%ARRHYTHMIA 420 objects with 279 features in 12 classes
[80]2%
3%        X = ARRHYTHMIA(CLASS,VAL)
4%
5% The aim is to distinguish between the presence and absence of cardiac
6% arrhythmia and to classify it in one of the 16 groups. Class 01 refers
7% to 'normal' ECG classes 02 to 15 refers to different classes of
8% arrhythmia and class 16 refers to the rest of unclassified ones.
9%
10%       X = ARRHYTHMIA(VAL);
11%
[96]12% By default features with missing values are removed. When something else
13% is desired, use one of the options in MISVAL.
[94]14%
15% SEE ALSO <a href="http://37steps.com/prtools">PRTools Guide</a>, <a href="http://archive.ics.uci.edu/ml/">UCI Website</a>
16% PRTOOLS, DATASETS, MISVAL
17
18% Copyright: R.P.W. Duin, r.p.w.duin@prtools.org
19
[80]20function x = arrhythmia(val);
21
22prdatasets(mfilename,1,'http://prtools.org/prdatasets/arrhythmia.dat');
23if nargin<1
[96]24        val = 'f-remove';
[80]25end
26
27user.desc='The Arrhymthmia database from UCI. The aim is to distinguish between the presence and absence of cardiac arrhythmia and to classify it in one of the 16 groups.';
28user.link = 'ftp://ftp.ics.uci.edu/pub/machine-learning-databases/arrhythmia';
29
30fl = {'age' 'sex' 'height' 'weight' 'QRS duration' 'P-R interval' ...
31'Q-T interval' 'T interval' 'P interval' 'QRS' 'T' 'P' 'QRST' ...
32'J' 'heartrate'};
33fl1 = {'Q wave width' 'R wave width' 'S wave width' 'R'' wave width' ...
34'S'' wave width' 'number of intrinsic deflections' ...
35'ragged R wave' 'diphasic derivation of R wave' ...
36'ragged P wave' 'diphasic derivation of P wave' ...
37'ragged T wave' 'diphasic derivation of T wave'};
38fl = [fl strcat('DI-',fl1) strcat('DII-',fl1) strcat('DIII-',fl1) ...
39strcat('AVR-',fl1) strcat('AVL-',fl1) strcat('AVF-',fl1) ...
40strcat('V1-',fl1) strcat('V2-',fl1) strcat('V3-',fl1) ...
41strcat('V4-',fl1) strcat('V5-',fl1) strcat('V6-',fl1)];
42fl2 = {'JJ wave ampl' 'Q wave ampl' 'R wave ampl' ...
43'S wave ampl' 'R'' wave ampl' 'S'' wave ampl' 'P wave ampl' ...
44'T wave ampl' 'QRSA sum' 'QRSTA'};
45fl = [fl strcat('DI-',fl2) strcat('DII-',fl2) strcat('DIII-',fl2) ...
46strcat('AVR-',fl2) strcat('AVL-',fl2) strcat('AVF-',fl2) ...
47strcat('V1-',fl2) strcat('V2-',fl2) strcat('V3-',fl2) ...
48strcat('V4-',fl2) strcat('V5-',fl2) strcat('V6-',fl2)];
49
50a = load('arrhythmia.dat');
[81]51x = pr_dataset(a(:,1:(end-1)),a(:,end));
[80]52x = setfeatlab(x,fl);
53x = setname(x,'Arrhythmia normal');
[96]54x = setuser(x,user);
[94]55%x(:,14) = [];  % there are so many missing values, that I just remove this
56%               % don't do this, nice but confusing
[96]57x = misval(x,val);
58% user.desc = [user.desc msg];
59% x = setuser(x,user);
[80]60x = setlablist(x);
61return
Note: See TracBrowser for help on using the repository browser.