36 #ifndef TPOLYNOMIALCHAOS_H 37 #define TPOLYNOMIALCHAOS_H 44 #include "TDataServer.h" 50 #include "nisp_util.h" 71 PolynomialChaos *
_pc;
137 void setDegree(Int_t degree);
145 void setAutoDegreeFactor(
double autodeg);
153 void setAutoDegreeBoundaries(
int amin,
int amax=-1);
158 return _degreeResults;
172 void computeOutput(
double *input);
180 Double_t getOutput(TString jname =
"");
186 Double_t getOutput(Int_t j);
192 Double_t getEqmLoo(Int_t rank=0);
199 Double_t getErrLoo(Int_t input, Int_t rank=0);
202 double factorial(
int n);
209 void automatisedDegree(Option_t *option =
"");
215 void computeChaosExpansion(TString type, Option_t * option =
"");
221 Double_t getMean(Int_t j);
229 Double_t getMean(TString name =
"");
235 Double_t getVariance(Int_t j);
243 Double_t getVariance(TString name =
"");
250 Double_t getCovariance(Int_t i, Int_t j);
259 Double_t getCovariance(TString xname, TString yname);
266 Double_t getCorrelation(Int_t i, Int_t j);
275 Double_t getCorrelation(TString xname, TString yname);
282 Double_t getIndexFirstOrder(Int_t i, Int_t j = 0);
291 Double_t getIndexFirstOrder(TString xname, TString yname =
"");
298 Double_t getIndexTotalOrder(Int_t i, Int_t j = 0);
307 Double_t getIndexTotalOrder(TString xname, TString yname =
"");
314 Double_t getIndex(TString sinput =
"", TString yname =
"");
321 Double_t getIndexInteraction(TString sinput =
"", TString yname =
"");
326 Int_t getDimensionInput();
331 Int_t getDimensionOutput();
336 Int_t getDimensionExpansion();
348 void exportFunction(
const char *file =
"nisp",
349 const char *name =
"nisp_fct");
356 Double_t getCoefficient(Int_t k, TString jname =
"");
370 _blog = _blog ? kFALSE : kTRUE;
376 virtual void printLog(Option_t *option =
"");
389 void setGroupAddVar(Int_t i);
394 void writeCodeCToDenormalizeInput(std::ofstream * sourcefile);
399 void setGroupEmpty();
409 void setCoefficient(Int_t noutput, Int_t num, Double_t coef);
417 Double_t getCoefficient(Int_t noutput, Int_t num);
430 void generateSample(TString type, Int_t np, Int_t order=1);
434 Double_t getSample(Int_t k, Int_t j);
439 Double_t getSample(Int_t k, TString yname);
449 void getAnova(Int_t nt);
453 void getAnovaOrdered(Double_t seuil, Int_t j);
461 void getAnovaOrdered(Double_t seuil, TString yname =
"");
465 void getAnovaOrderedCoefficients(Double_t seuil, Int_t j);
473 void getAnovaOrderedCoefficients(Double_t seuil, TString yname =
"");
479 Double_t getQuantile(Double_t alpha, Int_t j);
487 Double_t getQuantile(Double_t alpha, TString yname);
494 Double_t getQuantileWilks(Double_t alpha, Double_t beta, Int_t j = 1);
503 Double_t getQuantileWilks(Double_t alpha, Double_t beta, TString yname);
509 Double_t getInvQuantile(Double_t seuil, Int_t j = 1);
517 Double_t getInvQuantile(Double_t seuil, TString yname);
521 void readTarget(Char_t *file);
525 void setInput(Int_t nt, Double_t dt);
529 void propagateInput();
533 void propagateInput(Double_t *dt);
538 void save(Char_t *file);
539 void save(
string file);
ROOT.
Definition: TAnisp.h:163
int _bestAutoDeg
Best value for automatic degree scan.
Definition: TPolynomialChaos.h:84
Bool_t _blog
Boolean for edit the log.
Definition: TPolynomialChaos.h:94
Interface of the class URANIE::Modeler::TNisp.
int _maxAutoDeg
Maximal value for automatic degree scan.
Definition: TPolynomialChaos.h:83
PolynomialChaos * _pc
Object of type polynomialChaos (library Nisp)
Definition: TPolynomialChaos.h:71
Int_t _ny
Definition: TPolynomialChaos.h:77
Description of the class TNisp.
Definition: TNisp.h:61
TTree * getAutoDegreeResults()
Return a pointer to the TTree that contains the degree optimisation results.
Definition: TPolynomialChaos.h:156
Int_t _nx
Number of stochastic variables i.e number of input.
Definition: TPolynomialChaos.h:73
double _autoDegreeFactor
Factor used to scale the maximum degree knowing _nx and _np.
Definition: TPolynomialChaos.h:81
Bool_t getLog()
Definition: TPolynomialChaos.h:372
TNisp * _nisp
Message logger.
Definition: TPolynomialChaos.h:67
void unsetLog()
Definition: TPolynomialChaos.h:364
void changeLog()
Definition: TPolynomialChaos.h:368
int _minAutoDeg
Minimal value for automatic degree scan.
Definition: TPolynomialChaos.h:82
double _eqmval
memory arry for the eqm in the tree
Definition: TPolynomialChaos.h:88
URANIE::DataServer::UMessageLogger * _fLogger
Definition: TPolynomialChaos.h:63
TTree * _degreeResults
TDSNtupleD used to store the results of the automatisedDegree method.
Definition: TPolynomialChaos.h:80
Description of the class TPolynomialChaos.
Definition: TPolynomialChaos.h:60
Bool_t _bStoreYHat
Boolean to specify if we add the {} attribute in the TDS [default kTRUE].
Definition: TPolynomialChaos.h:78
void setLog()
Definition: TPolynomialChaos.h:360
int _degval
memory arry for the degree in the tree
Definition: TPolynomialChaos.h:87
Int_t _degree
Degree of the Chaos polynomial.
Definition: TPolynomialChaos.h:69
vector< double > * _verrloo
vector to contains the err loo and store them in the tree
Definition: TPolynomialChaos.h:86
Int_t _np
Number of simulation.
Definition: TPolynomialChaos.h:75
TDataSpecification * _listAttOut
Object of type TDataSpecification used to index the name of the variables.
Definition: TPolynomialChaos.h:92
int getBestAutoDegree()
Return the bet estimated degree when optimisation is done with regression.
Definition: TPolynomialChaos.h:162