-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathapplyPrincipalComponentAnalysis.m
34 lines (30 loc) · 1.62 KB
/
applyPrincipalComponentAnalysis.m
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
function [coefficients, lastPrincipalComponentIndex] = applyPrincipalComponentAnalysis(input, threshold)
% Applica la PCA alla matrice di input. Successivamente, vengono calcolati
% quali sono i nuovi valori da mantenere nella nuova matrice trasformata,
% con l'approssimazione scelta dall'utente.
%
% Parametri di input
% input : Matrice da sottoporre alla principal component analysis
% threshold : Percentuale di approssimazione
%
% Parametri di output
% coefficients : e' una matrice le cui colonne rappresentano un autovettore
% della matrice di covarianza. Le colonne sono ordinate
% per valore decrescente rispetto gli autovalori corrispondenti.
% Vengono prese solo le colonne 1:lastPrincipalComponentIndex.
% lastPrincipalComponentIndex : Indice che rappresenta l'ultima colonna
% che abbiamo mantenuto nella nuova matrice
% dei coefficienti.
% Calcolo della PCA
[coefficients, scores] = principalComponentAnalysis(input);
% Utilizza la varianza per selezionare il threshold% delle colonne da
% mantenere nella nuova matrice dei coefficienti
currentCoverage = 0.0;
lastPrincipalComponentIndex = 1;
while (lastPrincipalComponentIndex <= size(scores,1)) && (currentCoverage <= threshold)
currentCoverage = currentCoverage + scores(lastPrincipalComponentIndex);
lastPrincipalComponentIndex = lastPrincipalComponentIndex + 1;
end
% Nuova matrice dei coefficienti
coefficients = coefficients(:, 1:lastPrincipalComponentIndex);
end