520 likes | 615 Vues
Analyzing Patterns Using Principal Component Analysis. BMSC601 W. Rose. Hubley-Kozey et al. (2006) “Neuromuscular alterations during walking…”, J. Electromyo. Kinesiol. 16 : 365-378.
E N D
Analyzing Patterns Using Principal Component Analysis BMSC601 W. Rose
Hubley-Kozey et al. (2006) “Neuromuscular alterations during walking…”, J. Electromyo. Kinesiol.16: 365-378. EMGs and kinematic data are complex, or “high-dimensional”, i.e. they have a lot of numbers: they vary with time and by site. Pattern analysis tries to find patterns in complex data, and thus to reduce complex data to a smaller set of numbers that can be quantitatively compared (“data reduction”). Principal component analysis (PCA) is one kind of pattern analysis. PCA BMSC601 W. Rose
Assume we have multiple “copies” of a signal. The copies could be from multiple trials in one person, or from different people, etc. Goal Find patterns in the signals and quantify whether there are differences in patterns between subgroups. PCA BMSC601 W. Rose
PCA Approach to the Goal Find the pattern (wave shape) which, when scaled up or down by an adjustable scaling factor, accounts for as much of the power as possible in the signals. This is the first principal component. The scaling factor is adjusted for each trial individually, but the basic shape is not adjustable and cannot “slide” along the time axis. PCA BMSC601 W. Rose
PCA Approach to the Goal, cont. Best basic shape = 1st principal component. Once 1st PC is found, find scale factor for each trial. Scale factor tells us “how much” of the 1st PC there is in each trial. (Scale factor could even be negative.) Collect scale factors from “experimentals” & controls and compare them using standard statistics (t test, Wilcoxon rank-sum, ANOVA, etc), to see if scale factors differ from group to group. If they do, it means that “size” of 1st PC is different in diff. groups. PCA BMSC601 W. Rose
PCA Approach to the Goal, cont. Scaled versions of 1st PC can be subtracted from each signal to get “first residual” for each trial, i.e. the part of signal not accounted for by 1st PC. Now repeat what we did before, using 1st residuals of each signal, instead of the actual signals. The shape which, when scaled separately for each trial, does the best job in accounting for the 1st residuals, is the 2nd PC. PCA for EMGs BMSC601 W. Rose
PCA Approach to the Goal, cont. As with 1st PC, we find a scale factor for each trial. The scale factor is “how much” of 2nd PC there is in each trial, i.e. it’s the amount that 2nd PC should be multiplied by to get best fit to that trial’s 1st residual. Once again, we can use statistics to compare 2nd PC scale factors across groups to see if “size” of 2nd PC is different in diff. groups. PCA for EMGs BMSC601 W. Rose
PCA Approach to the Goal, cont. We now compute “2nd residuals” by subtracting the scaled version of 2nd PC from each 1st residual. We use the 2nd residuals to get the third PC, the scaling factors for 3rd PC, and so on. If there are N time points in each signal, we can keep going until we find N principal components. PCA BMSC601 W. Rose
The high numbered PCs are probably not very significant. They may be just fitting the noise. How many PCs should we analyze? Standard Answers: Accept only enough PCs to account for 90% (or 95%) of the variance in the original signals Or Accept PCs until the next one accounts for less than 1% of the variance in the original signals. PCA BMSC601 W. Rose
PCA as described above is done on signals whose mean values have been subtracted off, so the signals analyzed WILL have zero mean value. If desired, the means can be added back on at the end. Hubley-Kozey et al. use Karhunen-Loeve transformation (KLT). Raptopoulos et al. (J Biomech 2006) use “KLT”; they DO subtract mean values first. Raptop 2006 use correlation mtx instead of covariance mtx. PCA BMSC601 W. Rose
In PCA and KLT, start with matrix X whose columns are the signals (e.g. EMGs) from diff. subjects. Rows are different time points. KLT and PCA: compute Cov(X) (or Corr(X): Raptopoulos et al 2006; Schutte et al 2000; Deluzio et al 1997) Cov(X) = [X-E(X)]*[X-E(X)]T / (m-1) E(X) = matrix whose every column = the mean vector. Eigenvectors of Cov(X) are the PCs. Eigenvalues of Cov(X) indicate how much of the variance is accounted for by each PC. PCA BMSC601 W. Rose
Acc. Gerbrands, 1981: KLT: compute y = TT x PCA: compute y = TT [x-E(x)] where E(x)=mean vector. Hall Müller Wang 2006 define KLT with de-meaned X; equate KLT with “functional PCA” PCA BMSC601 W. Rose
Simulate some EMGs. Each EMG is a weighted sum of 4 components (pulses). The weight (i.e. factor that multiplies the y-scale) of each component is a random number between -1,+1. The random numbers differ from trace to trace. Some random noise is also added at each time point. PCA W. Rose BMSC601
PCA BMSC601 W. Rose
PCA Set 1: s1 thru s4≈ (-1,1). Six examples, mean of 20 shown. BMSC601 W. Rose
Example: running a PCA program in Matlab >> PCA02 Enter name of text file containing data (.txt will be added): EMG_set1 100 rows (=times); 20 columns (=different signals) k(90%)=3, k(95%)=4, k(1%)=4 PC weight +- SE %Var accounted for 1 -0.337 +- 0.59 46.4 2 -0.101 +- 0.47 30.2 3 +0.162 +- 0.33 14.7 4 -0.046 +- 0.23 7.0 5 +0.011 +- 0.04 0.2 6 +0.006 +- 0.04 0.2 1 thru 10 11 thru 20 PC weight +- SE weight +- SE 1 -0.480 +- 0.78 -0.193 +- 0.91 2 0.515 +- 0.72 -0.716 +- 0.58 3 -0.142 +- 0.31 0.465 +- 0.58 4 -0.148 +- 0.33 0.055 +- 0.33 Variables saved in EMG_set1_PCA2.mat. >> PCA The program also makes 3 plots. W. Rose BMSC601
PCA BMSC601 W. Rose
PCA BMSC601 W. Rose
PCA Set 1L: s1 thru s4≈ (-1,1); M=20 W. Rose BMSC601
PCA Set 1L1: s1 thru s4≈ (-1,1); M=100. W. Rose BMSC601
PCA Set 1L2: s1 thru s4≈ (-1,1); M=100. W. Rose BMSC601
PCA Set 1VL: s1 thru s4≈ (-1,1); M=200. W. Rose BMSC601
PCA Set 1VL: s1 thru s4≈ (-1,1); M=200. W. Rose BMSC601
PCA Set 1VL: s1 thru s4≈ (-1,1); M=200. W. Rose BMSC601
Do it again using Hubley-Kozey’s version of KLT (i.e. without de-meaning) [Need to check KLT graphs and software to see if it correctly used the covariance matrix – WCR 2006-11-16] PCA W. Rose BMSC601
KLT KLT (H-K) BMSC601 W. Rose
KLT (H-K) KLT PCA BMSC601 W. Rose
KLT (H-K) PCA BMSC601 W. Rose
KLT BMSC601 KLT (H-K) W. Rose
KLT (H-K) (no de-meaning PCA For this data (EMG_set1.txt), mean values ~= 0 so get similar results with both methods. PCA W. Rose BMSC601
Simulate EMGs using same four components (pulses) as before. Make two populations whose random weights (s1 to s4) for the components are randomly distributed over the following intervals: PCA W. Rose BMSC601
PCA BMSC601 W. Rose
PCA s1 thru s4≈ (1,3) Six examples, mean of 20 shown. BMSC601 W. Rose
PCA s1, s3≈ (1,3); s2 ≈ (1,2); s4 ≈ (1,4) Six examples, mean of 20 shown. BMSC601 W. Rose
PCA Set 2a: s1, s2, s3, s4 ≈ (1,3) Set 2b: s1, s3≈ (1,3); s2 ≈ (1,2); s4 ≈ (1,4) BMSC601 W. Rose
Analysis of Simulated Data Set 2 >> PCA02 Enter name of text file containing data (.txt will be added): EMG_set2 100 rows (=times); 40 columns (=different signals) k(90%)=4, k(95%)=4, k(1%)=4 PC weight +- SE %Var accounted for 1 -0.977 +- 0.37 40.4 2 -0.163 +- 0.32 28.8 3 -0.870 +- 0.27 20.8 4 -7.389 +- 0.17 8.0 5 -0.119 +- 0.02 0.1 6 -0.032 +- 0.02 0.1 1 thru 20 21 thru 40 PC weight +- SE weight +- SE 1 -1.556 +- 0.49 -0.397 +- 0.55 2 -0.981 +- 0.42 0.655 +- 0.40 3 -0.192 +- 0.44 -1.549 +- 0.23 4 -7.554 +- 0.23 -7.224 +- 0.24 Variables saved in EMG_set2_PCA2.mat. >> PCA W. Rose BMSC601
PCA Set 2: s1 thru s4≈ (1,3); M=40 W. Rose BMSC601
PCA Set 2: s1 thru s4≈ (1,3); M=40 W. Rose BMSC601
Do it again using Hubley-Kozey’s version of KLT (i.e. without de-meaning) [Need to check KLT graphs and software to see if it correctly used the covariance matrix – WCR 2006-11-16] PCA W. Rose BMSC601
KLT KLT (H-K) BMSC601 W. Rose
KLT (H-K) KLT PCA BMSC601 W. Rose
KLT (H-K) PCA BMSC601 W. Rose
KLT Reconstruction with 1 PC. BMSC601 KLT (H-K style) W. Rose
KLT without demeaning seems much worse but only because it is reconstructing with 1 PC, since this reconstr uses PCs sufficient to get >=90% of variance. Need to change this to include first 4 PCs for both reconstructions. [Need to check KLT graphs and software to see if it correctly used the covariance matrix – WCR 2006-11-16] KLT (H-K) PCA PCA W. Rose BMSC601
New simulated data set: EMG_set3. Pulses used are same as before. Weights are greater for pulses with greater variances. (All 4 pulses have min=0, max=1, but some are wider so have greater power.) Will this allow PCA to find PCs that correspond better to the original pulses? s1=(4,8) s2=(2,6) s3=(3,7) s4a=(1,5) (m=40) s1=(4,8) s2=(2,6) s3=(3,7) s4b=(0,4) (m=40) PCA W. Rose BMSC601
PCA Set 3: s1≈ (4,8), s2 ≈ (2,6),s3 ≈ (3,7),s4a ≈ (1,5), s4b ≈ (0,4) m=80 (40 each) BMSC601 W. Rose
PCA PCA Set 3: s1≈ (4,8), s2 ≈ (2,6),s3 ≈ (3,7),s4a ≈ (1,5), s4b ≈ (0,4); m=80 BMSC601 W. Rose
PCA Set 3: s1≈ (4,8), s2 ≈ (2,6),s3 ≈ (3,7),s4a ≈ (1,5), s4b ≈ (0,4); m=80 BMSC601 PCA W. Rose
Do it again using Hubley-Kozey’s version of KLT (i.e. without de-meaning) [Need to check KLT graphs and software to see if it correctly used the covariance matrix – WCR 2006-11-16] PCA W. Rose BMSC601
PCA PCA without de-meaning Set 3: s1≈ (4,8), s2 ≈ (2,6),s3 ≈ (3,7),s4a ≈ (1,5), s4b ≈ (0,4); m=80 BMSC601 W. Rose