root / tmp / org.txm.analec.rcp / src / JamaPlus / AFC.java @ 875
Historique | Voir | Annoter | Télécharger (1,94 ko)
1 |
/*
|
---|---|
2 |
* To change this template, choose Tools | Templates
|
3 |
* and open the template in the editor.
|
4 |
*/
|
5 |
package JamaPlus; |
6 |
|
7 |
/**
|
8 |
*
|
9 |
* AFC analyse factorielle des correspondances (optimisé mémoire)
|
10 |
* mat : matrice binaire (0. ou 1.) profil des lignes (un individu par ligne, un caractère par colonne)
|
11 |
* CP: composantes principales,
|
12 |
* VP: valeurs d'inertie,
|
13 |
* CG: centres de gravité des CP contenant un même caractère (non calculé dans cette version)
|
14 |
* [p,q] = size(mat); p:nb de lignes, q:nb de col
|
15 |
*
|
16 |
* @author Bernard
|
17 |
*/
|
18 |
public class AFC { |
19 |
|
20 |
private double[][] CP; |
21 |
private double[] VP; |
22 |
private int p, q, n; |
23 |
|
24 |
AFC(Matrix Arg) { |
25 |
Matrix mat = Arg.copy(); |
26 |
mat = mat.nulColumnSuppression(); |
27 |
p = mat.getRowDimension(); |
28 |
q = mat.getColumnDimension(); |
29 |
n = Math.min(Math.min(p, q), 5); // n : nombre de composantes principales calculées |
30 |
if (n == 0) return; |
31 |
if (n == 1) { |
32 |
CP = new double[p][1]; |
33 |
VP = new double[1]; |
34 |
return;
|
35 |
} |
36 |
double f = mat.elementSum();
|
37 |
if (f == 0) return; |
38 |
mat = mat.timesEquals(1 / f);
|
39 |
Matrix r = mat.lineSum(); |
40 |
Matrix r1 = r.arrayInverse(); |
41 |
Matrix r2 = r.arraySqrt(); |
42 |
Matrix r3 = r2.arrayInverse(); |
43 |
Matrix c = mat.columnSum(); |
44 |
Matrix c1 = c.arrayInverse(); |
45 |
Matrix c2 = c.arraySqrt(); |
46 |
Matrix c3 = c2.arrayInverse(); |
47 |
mat = mat.firstColumnTimesEqual(r3); |
48 |
mat = mat.firstLineTimesEqual(c3); |
49 |
SingularValueDecomposition svd = mat.svd(); |
50 |
Matrix cp = svd.getU(); |
51 |
Matrix vp = new Matrix(svd.getSingularValues(), 1); |
52 |
cp = cp.getMatrix(0, p - 1, 1, n - 1); |
53 |
cp = cp.firstColumnTimesEqual(r2); |
54 |
vp = vp.getMatrix(0, 0, 1, n - 1); |
55 |
cp = cp.firstLineTimesEqual(vp); |
56 |
cp.fixColumnSigns(); |
57 |
cp = cp.firstColumnTimesEqual(r1); |
58 |
CP = cp.getArray(); |
59 |
VP = vp.getColumnPackedCopy(); |
60 |
} |
61 |
|
62 |
public Matrix getCP() {
|
63 |
if (CP == null) return null; |
64 |
return new Matrix(CP, p, n - 1); |
65 |
} |
66 |
|
67 |
public double[] getVP() { |
68 |
return VP;
|
69 |
} |
70 |
} |