-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathPCA_various_methods.asv
47 lines (42 loc) · 1.13 KB
/
PCA_various_methods.asv
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
load("chb01_01_edfm.mat");
m_eeg = val';
%% PCA
% Direcciones que maximizan la varianza
% Todos los eigenvectores son unitarios
S = cov(m_eeg);% covarianza entre variables
% Obtener eigenvectores y eigenvalores de la matriz de covarianza
[eig_vect,eig_val] = eig(S);
% Ordenar en orden descendente los eigenvalores y eigenvectores
eig_val = sort(diag(eig_val),'descend');
eig_vect = fliplr(eig_vect);
% Explained variance to choose the most significant components
tot = sum(eig_val);
var_exp = [];
c = {};
len = length(eig_val);
for i = 1:length(eig_val)
var_exp(i) = (eig_val(i)/tot)*100;
% c{i} = strcat('PCA ',num2str(len));
% len = len-1;
end
% c = categorical(c);
cum=cumsum(var_exp);
figure;
bar(var_exp);
title("Explained variance by different principal components");
ylabel("Explained variance in percent");
grid on;
hold;
plot(cum);
% Obtención de la matriz de proyección (concatenación de los primeros eigenv)
% criterio del 95% de la varianza
var = 0;cont=1;
mask = zeros();
while(var<=95)
var = var+var_exp(cont);
mask(cont) = cont;
cont=cont+1;
end
new_feat = eig_vect(:,mask);
% Proyección en el nuevo espacio
Y = ;