Logo ROOT   6.12/07
Reference Guide
pca.C
Go to the documentation of this file.
1 // -*- mode: c++ -*-
2 //
3 // File pca.C generated by TPrincipal::MakeCode
4 // on Sat Sep 29 22:13:58 2018
5 // ROOT version 6.12/07
6 //
7 // This file contains the functions
8 //
9 // void X2P(Double_t *x, Double_t *p);
10 // void P2X(Double_t *p, Double_t *x, Int_t nTest);
11 //
12 // The first for transforming original data x in
13 // pattern space, to principal components p in
14 // feature space. The second function is for the
15 // inverse transformation, but using only nTest
16 // of the principal components in the expansion
17 //
18 // See TPrincipal class documentation for more information
19 //
20 #ifndef __CINT__
21 #include <Rtypes.h> // needed for Double_t etc
22 #endif
23 
24 //
25 // Static data variables
26 //
27 static Int_t gNVariables = 10;
28 
29 // Assignment of eigenvector matrix.
30 // Elements are stored row-wise, that is
31 // M[i][j] = e[i * nVariables + j]
32 // where i and j are zero-based
33 static Double_t gEigenVectors[] = {
34  0.105952,
35  -0.0412338,
36  -0.163932,
37  0.506955,
38  -0.293327,
39  -0.45912,
40  0.611921,
41  0.0417098,
42  0.124369,
43  -0.121286,
44  0.299103,
45  0.114816,
46  -0.423035,
47  0.173049,
48  0.129852,
49  -0.264772,
50  -0.58561,
51  0.118711,
52  0.35397,
53  -0.345193,
54  0.196631,
55  0.182178,
56  0.334538,
57  0.0979602,
58  -0.695575,
59  0.431875,
60  -0.124202,
61  0.0811669,
62  0.242022,
63  -0.236021,
64  0.0946521,
65  0.0513485,
66  0.107011,
67  0.552681,
68  0.561861,
69  0.539862,
70  0.180077,
71  0.041718,
72  0.124394,
73  -0.121309,
74  0.294184,
75  0.179444,
76  0.157981,
77  -0.594249,
78  0.257622,
79  -0.0673251,
80  0.421439,
81  0.117814,
82  0.351295,
83  -0.342585,
84  0.135669,
85  -0.895902,
86  -0.0723783,
87  -0.0912176,
88  -0.0511243,
89  0.155245,
90  0.0072091,
91  -0.0686794,
92  0.36119,
93  0.0587528,
94  0.0393664,
95  -0.129504,
96  0.791462,
97  0.188712,
98  0.167449,
99  -0.456201,
100  -0.235961,
101  -0.142627,
102  0.0747034,
103  -0.0435387,
104  0.501306,
105  -0.134663,
106  0.0961035,
107  0.0147716,
108  0.015782,
109  -0.0347285,
110  -0.0292305,
111  0.724996,
112  -0.379729,
113  0.221314,
114  0.503961,
115  -0.111486,
116  -0.060855,
117  -0.0228244,
118  -0.0175214,
119  0.0561781,
120  0.0175518,
121  -0.534241,
122  -0.552628,
123  -0.367135,
124  0.4898,
125  0.259068,
126  -0.0353844,
127  0.0139158,
128  0.00266293,
129  -0.00485772,
130  0.0160046,
131  -0.354777,
132  0.275952,
133  0.69945};
134 
135 // Assignment to eigen value vector. Zero-based.
136 static Double_t gEigenValues[] = {
137  0.385122,
138  0.110703,
139  0.103572,
140  0.101548,
141  0.100795,
142  0.0996221,
143  0.0986388,
144  5.97928e-16,
145  2.52544e-16,
146  5.65803e-16
147 };
148 
149 // Assignment to mean value vector. Zero-based.
150 static Double_t gMeanValues[] = {
151  5.0082,
152  7.9976,
153  1.96735,
154  5.0162,
155  8.0087,
156  2.01253,
157  4.99247,
158  35.0031,
159  30.0106,
160  27.9981
161 };
162 
163 // Assignment to sigma value vector. Zero-based.
164 static Double_t gSigmaValues[] = {
165  1.00507,
166  2.86056,
167  1.95587,
168  1.00527,
169  2.83895,
170  1.97263,
171  1.01426,
172  5.15563,
173  5.04925,
174  4.64883
175 };
176 
177 //
178 // The function void X2P(Double_t *x, Double_t *p)
179 //
180 void X2P(Double_t *x, Double_t *p) {
181  for (Int_t i = 0; i < gNVariables; i++) {
182  p[i] = 0;
183  for (Int_t j = 0; j < gNVariables; j++)
184  p[i] += (x[j] - gMeanValues[j])
185  * gEigenVectors[j * gNVariables + i] / gSigmaValues[j];
186 
187  }
188 }
189 
190 //
191 // The function void P2X(Double_t *p, Double_t *x, Int_t nTest)
192 //
193 void P2X(Double_t *p, Double_t *x, Int_t nTest) {
194  for (Int_t i = 0; i < gNVariables; i++) {
195  x[i] = gMeanValues[i];
196  for (Int_t j = 0; j < nTest; j++)
197  x[i] += p[j] * gSigmaValues[i]
198  * gEigenVectors[i * gNVariables + j];
199  }
200 }
201 
202 // EOF for pca.C
void X2P(Double_t *x, Double_t *p)
Definition: pca.C:180
static Int_t gNVariables
Definition: pca.C:27
int Int_t
Definition: RtypesCore.h:41
static Double_t gEigenVectors[]
Definition: pca.C:33
Double_t x[n]
Definition: legend1.C:17
static Double_t gSigmaValues[]
Definition: pca.C:164
void P2X(Double_t *p, Double_t *x, Int_t nTest)
Definition: pca.C:193
static Double_t gEigenValues[]
Definition: pca.C:136
double Double_t
Definition: RtypesCore.h:55
static Double_t gMeanValues[]
Definition: pca.C:150