141 #pragma warning ( disable : 4355 ) 177 std::cerr << kERROR <<
"IPythonInteractive::Init: already initialized..." << std::endl;
181 for(
auto& title : graphTitles){
183 fGraphs.back()->SetTitle(title);
184 fGraphs.back()->SetName(title);
185 fGraphs.back()->SetFillColor(color);
186 fGraphs.back()->SetLineColor(color);
187 fGraphs.back()->SetMarkerColor(color);
252 fAnalysisType (
Types::kNoAnalysisType ),
253 fRegressionReturnVal ( 0 ),
254 fMulticlassReturnVal ( 0 ),
255 fDataSetInfo ( dsi ),
256 fSignalReferenceCut ( 0.5 ),
257 fSignalReferenceCutOrientation( 1. ),
258 fVariableTransformType (
Types::kSignal ),
259 fJobName ( jobName ),
260 fMethodName ( methodTitle ),
261 fMethodType ( methodType ),
265 fConstructedFromWeightFile (
kFALSE ),
267 fMethodBaseDir ( 0 ),
270 fModelPersistence (
kTRUE),
281 fSplTrainEffBvsS ( 0 ),
282 fVarTransformString (
"None" ),
283 fTransformationPointer ( 0 ),
284 fTransformation ( dsi, methodTitle ),
286 fVerbosityLevelString (
"Default" ),
289 fIgnoreNegWeightsInTraining(
kFALSE ),
291 fBackgroundClass ( 0 ),
393 for (
Int_t i = 0; i < 2; i++ ) {
485 if (
DataInfo().GetClassInfo(
"Signal") != 0) {
488 if (
DataInfo().GetClassInfo(
"Background") != 0) {
516 DeclareOptionRef(
fVerbose,
"V",
"Verbose output (short form of \"VerbosityLevel\" below - overrides the latter one)" );
532 DeclareOptionRef(
fVarTransformString,
"VarTransform",
"List of variable transformations performed before training, e.g., \"D_Background,P_Signal,G,N_AllClasses\" for: \"Decorrelation, PCA-transformation, Gaussianisation, Normalisation, each for the given class of events ('AllClasses' denotes all events of all classes, if no class indication is given, 'All' is assumed)\"" );
539 "Events with negative weights are ignored in the training (but are included for testing and performance evaluation)" );
590 Log() << kFATAL <<
"<ProcessOptions> Verbosity level type '" 606 "Use signal or background events to derive for variable transformation (the transformation is applied on both types of, course)" );
634 Log() << kWARNING <<
Form(
"Dataset[%s] : ",
DataInfo().
GetName())<<
"Parameter optimization is not yet implemented for method " 636 Log() << kWARNING <<
Form(
"Dataset[%s] : ",
DataInfo().
GetName())<<
"Currently we need to set hardcoded which parameter is tuned in which ranges"<<
Endl;
638 std::map<TString,Double_t> tunedParameters;
639 tunedParameters.size();
640 return tunedParameters;
672 <<
"Begin training" <<
Endl;
677 <<
"\tEnd of training " <<
Endl;
680 <<
"Elapsed time for training with " << nEvents <<
" events: " 684 <<
"\tCreate MVA output for ";
734 bool truncate =
false;
735 TH1F*
h1 = regRes->QuadraticDeviation( tgtNum , truncate, 1.);
740 TH1F* h2 = regRes->QuadraticDeviation( tgtNum , truncate, yq[0]);
764 regRes->Resize( nEvents );
765 for (
Int_t ievt=0; ievt<nEvents; ievt++) {
768 regRes->SetValue( vals, ievt );
773 <<
"Elapsed time for evaluation of " << nEvents <<
" events: " 782 regRes->CreateDeviationHistograms( histNamePrefix );
795 if (!resMulticlass)
Log() << kFATAL<<
Form(
"Dataset[%s] : ",
DataInfo().
GetName())<<
"unable to create pointer in AddMulticlassOutput, exiting."<<
Endl;
805 resMulticlass->
Resize( nEvents );
806 for (
Int_t ievt=0; ievt<nEvents; ievt++) {
809 resMulticlass->SetValue( vals, ievt );
814 <<
"Elapsed time for evaluation of " << nEvents <<
" events: " 824 resMulticlass->CreateMulticlassPerformanceHistos(histNamePrefix);
831 if (errUpper) *errUpper=-1;
873 std::vector<Double_t> mvaValues =
GetMvaValues(0, nEvents,
true);
880 for (
Int_t ievt=0; ievt<nEvents; ievt++) {
881 clRes->
SetValue( mvaValues[ievt], ievt );
891 if (firstEvt > lastEvt || lastEvt > nEvents) lastEvt = nEvents;
892 if (firstEvt < 0) firstEvt = 0;
893 std::vector<Double_t> values(lastEvt-firstEvt);
895 nEvents = values.size();
905 for (
Int_t ievt=firstEvt; ievt<lastEvt; ievt++) {
912 if (modulo <= 0 ) modulo = 1;
918 <<
"Elapsed time for evaluation of " << nEvents <<
" events: " 943 mvaProb->
Resize( nEvents );
944 for (
Int_t ievt=0; ievt<nEvents; ievt++) {
948 if (proba < 0)
break;
953 if (modulo <= 0 ) modulo = 1;
958 <<
"Elapsed time for evaluation of " << nEvents <<
" events: " 979 bias = 0; biasT = 0; dev = 0; devT = 0; rms = 0; rmsT = 0;
981 Double_t m1 = 0,
m2 = 0, s1 = 0, s2 = 0, s12 = 0;
987 for (
Long64_t ievt=0; ievt<nevt; ievt++) {
1011 m1 += t*w; s1 += t*t*w;
1012 m2 += r*w; s2 += r*r*w;
1025 corr = s12/sumw - m1*
m2;
1026 corr /=
TMath::Sqrt( (s1/sumw - m1*m1) * (s2/sumw - m2*m2) );
1029 TH2F* hist =
new TH2F(
"hist",
"hist", 150, xmin, xmax, 100, xmin, xmax );
1030 TH2F* histT =
new TH2F(
"histT",
"histT", 150, xmin, xmax, 100, xmin, xmax );
1037 for (
Long64_t ievt=0; ievt<nevt; ievt++) {
1038 Float_t d = (rV[ievt] - tV[ievt]);
1039 hist->
Fill( rV[ievt], tV[ievt], wV[ievt] );
1040 if (d >= devMin && d <= devMax) {
1042 biasT += wV[ievt] * d;
1044 rmsT += wV[ievt] * d * d;
1045 histT->
Fill( rV[ievt], tV[ievt], wV[ievt] );
1073 if (!resMulticlass)
Log() << kFATAL<<
Form(
"Dataset[%s] : ",
DataInfo().
GetName())<<
"unable to create pointer in TestMulticlass, exiting."<<
Endl;
1096 <<
" not found in tree" <<
Endl;
1128 mvaRes->
Store(mva_s,
"MVA_S");
1129 mvaRes->
Store(mva_b,
"MVA_B");
1139 proba_s =
new TH1D( TestvarName +
"_Proba_S", TestvarName +
"_Proba_S",
fNbinsMVAoutput, 0.0, 1.0 );
1140 proba_b =
new TH1D( TestvarName +
"_Proba_B", TestvarName +
"_Proba_B",
fNbinsMVAoutput, 0.0, 1.0 );
1141 mvaRes->
Store(proba_s,
"Prob_S");
1142 mvaRes->
Store(proba_b,
"Prob_B");
1147 rarity_s =
new TH1D( TestvarName +
"_Rarity_S", TestvarName +
"_Rarity_S",
fNbinsMVAoutput, 0.0, 1.0 );
1148 rarity_b =
new TH1D( TestvarName +
"_Rarity_B", TestvarName +
"_Rarity_B",
fNbinsMVAoutput, 0.0, 1.0 );
1149 mvaRes->
Store(rarity_s,
"Rar_S");
1150 mvaRes->
Store(rarity_b,
"Rar_B");
1156 TH1* mva_eff_s =
new TH1D( TestvarName +
"_S_high", TestvarName +
"_S_high",
fNbinsH, fXmin, sxmax );
1157 TH1* mva_eff_b =
new TH1D( TestvarName +
"_B_high", TestvarName +
"_B_high",
fNbinsH, fXmin, sxmax );
1158 mvaRes->
Store(mva_eff_s,
"MVA_HIGHBIN_S");
1159 mvaRes->
Store(mva_eff_b,
"MVA_HIGHBIN_B");
1168 Log() << kHEADER <<
Form(
"[%s] : ",
DataInfo().
GetName())<<
"Loop over test events and fill histograms with classifier response..." <<
Endl <<
Endl;
1169 if (mvaProb)
Log() << kINFO <<
"Also filling probability and rarity histograms (on request)..." <<
Endl;
1185 mvaResTypes->push_back(
kTRUE);
1186 mva_s ->
Fill( v, w );
1188 proba_s->
Fill( (*mvaProb)[ievt][0], w );
1192 mva_eff_s ->
Fill( v, w );
1195 mvaResTypes->push_back(
kFALSE);
1196 mva_b ->
Fill( v, w );
1198 proba_b->
Fill( (*mvaProb)[ievt][0], w );
1201 mva_eff_b ->
Fill( v, w );
1231 tf << prefix <<
"#GEN -*-*-*-*-*-*-*-*-*-*-*- general info -*-*-*-*-*-*-*-*-*-*-*-" << std::endl << prefix << std::endl;
1233 tf.setf(std::ios::left);
1238 tf << prefix <<
"Creator : " << userInfo->
fUser << std::endl;
1247 tf << prefix << std::endl;
1252 tf << prefix << std::endl << prefix <<
"#OPT -*-*-*-*-*-*-*-*-*-*-*-*- options -*-*-*-*-*-*-*-*-*-*-*-*-" << std::endl << prefix << std::endl;
1254 tf << prefix << std::endl;
1257 tf << prefix << std::endl << prefix <<
"#VAR -*-*-*-*-*-*-*-*-*-*-*-* variables *-*-*-*-*-*-*-*-*-*-*-*-" << std::endl << prefix << std::endl;
1259 tf << prefix << std::endl;
1292 if (!parent)
return;
1371 <<
"Creating xml weight file: " 1392 <<
"Reading weight file: " 1396 #if ROOT_VERSION_CODE >= ROOT_VERSION(5,29,0) 1407 fb.open(tfname.
Data(),std::ios::in);
1408 if (!fb.is_open()) {
1410 <<
"Unable to open input weight file: " << tfname <<
Endl;
1412 std::istream fin(&fb);
1430 #if ROOT_VERSION_CODE >= ROOT_VERSION(5,26,00) 1436 Log() << kFATAL<<
Form(
"Dataset[%s] : ",
DataInfo().
GetName()) <<
"Method MethodBase::ReadStateFromXMLString( const char* xmlstr = " 1437 << xmlstr <<
" ) is not available for ROOT versions prior to 5.26/00." <<
Endl;
1464 if (nodeName==
"GeneralInfo") {
1469 while (antypeNode) {
1472 if (
name ==
"TrainingTime")
1475 if (
name ==
"AnalysisType") {
1484 if (
name ==
"TMVA Release" ||
name ==
"TMVA") {
1491 if (
name ==
"ROOT Release" ||
name ==
"ROOT") {
1501 else if (nodeName==
"Options") {
1506 else if (nodeName==
"Variables") {
1509 else if (nodeName==
"Spectators") {
1512 else if (nodeName==
"Classes") {
1515 else if (nodeName==
"Targets") {
1518 else if (nodeName==
"Transformations") {
1521 else if (nodeName==
"MVAPdfs") {
1536 else if (nodeName==
"Weights") {
1567 methodType = methodType(methodType.Last(
' '),methodType.Length());
1572 if (methodName ==
"") methodName = methodType;
1597 fin.getline(buf,512);
1598 while (!
TString(buf).BeginsWith(
"#VAR")) fin.getline(buf,512);
1630 fin.getline(buf,512);
1631 while (!
TString(buf).BeginsWith(
"#MAT")) fin.getline(buf,512);
1634 varTrafo->ReadTransformationFromStream(fin, trafo );
1645 fin.getline(buf,512);
1646 while (!
TString(buf).BeginsWith(
"#MVAPDFS")) fin.getline(buf,512);
1659 fin.getline(buf,512);
1660 while (!
TString(buf).BeginsWith(
"#WGT")) fin.getline(buf,512);
1661 fin.getline(buf,512);
1692 istr >> dummy >> readNVar;
1696 <<
" while there are " << readNVar <<
" variables declared in the file" 1712 Log() << kINFO <<
"The definition (or the order) of the variables found in the input file is" <<
Endl;
1713 Log() << kINFO <<
"is not the same as the one declared in the Reader (which is necessary for" <<
Endl;
1714 Log() << kINFO <<
"the correct working of the method):" <<
Endl;
1715 Log() << kINFO <<
" var #" << varIdx <<
" declared in Reader: " << varIt->GetExpression() <<
Endl;
1716 Log() << kINFO <<
" var #" << varIdx <<
" declared in file : " << varInfo.
GetExpression() <<
Endl;
1717 Log() << kFATAL <<
"The expression declared to the Reader needs to be checked (name or order are wrong)" <<
Endl;
1771 for (
UInt_t iCls=0; iCls<nClasses; ++iCls) {
1807 <<
" while there are " << readNVar <<
" variables declared in the file" 1822 existingVarInfo = readVarInfo;
1826 Log() << kINFO <<
"The definition (or the order) of the variables found in the input file is" <<
Endl;
1827 Log() << kINFO <<
"not the same as the one declared in the Reader (which is necessary for the" <<
Endl;
1828 Log() << kINFO <<
"correct working of the method):" <<
Endl;
1829 Log() << kINFO <<
" var #" << varIdx <<
" declared in Reader: " << existingVarInfo.
GetExpression() <<
Endl;
1830 Log() << kINFO <<
" var #" << varIdx <<
" declared in file : " << readVarInfo.
GetExpression() <<
Endl;
1831 Log() << kFATAL <<
"The expression declared to the Reader needs to be checked (name or order are wrong)" <<
Endl;
1847 <<
" while there are " << readNSpec <<
" spectators declared in the file" 1862 existingSpecInfo = readSpecInfo;
1866 Log() << kINFO <<
"The definition (or the order) of the spectators found in the input file is" <<
Endl;
1867 Log() << kINFO <<
"not the same as the one declared in the Reader (which is necessary for the" <<
Endl;
1868 Log() << kINFO <<
"correct working of the method):" <<
Endl;
1869 Log() << kINFO <<
" spec #" << specIdx <<
" declared in Reader: " << existingSpecInfo.
GetExpression() <<
Endl;
1870 Log() << kINFO <<
" spec #" << specIdx <<
" declared in file : " << readSpecInfo.
GetExpression() <<
Endl;
1871 Log() << kFATAL <<
"The expression declared to the Reader needs to be checked (name or order are wrong)" <<
Endl;
1890 for (
UInt_t icls = 0; icls<readNCls;++icls) {
1907 if (
DataInfo().GetClassInfo(
"Signal") != 0) {
1912 if (
DataInfo().GetClassInfo(
"Background") != 0) {
1950 Log() << kFATAL <<
Form(
"Dataset[%s] : ",
DataInfo().
GetName())<<
"MethodBase::BaseDir() - MethodBaseDir() return a NULL pointer!" <<
Endl;
1957 sdir = methodDir->
mkdir(defaultDir);
1962 wfilePath.Write(
"TrainingPath" );
1963 wfileName.Write(
"WeightFileName" );
1997 Log()<<kDEBUG<<
Form(
"Dataset[%s] : ",
DataInfo().
GetName())<<
"Return from MethodBaseDir() after creating base directory "<<
Endl;
2029 return ( wFileDir + (wFileDir[wFileDir.
Length()-1]==
'/' ?
"" :
"/")
2057 Log() << kFATAL <<
Form(
"Dataset[%s] : ",
DataInfo().
GetName())<<
"<WriteEvaluationHistosToFile> Unknown result: " 2059 <<
"/kMaxAnalysisType" <<
Endl;
2081 fin.getline(buf,512);
2087 std::stringstream
s(code.
Data());
2095 std::stringstream
s(code.
Data());
2103 std::stringstream
s(code.
Data());
2104 std::string analysisType;
2109 else Log() << kFATAL <<
"Analysis type " << analysisType <<
" from weight-file not known!" << std::endl;
2131 if (mvaRes==0 || mvaRes->
GetSize()==0) {
2132 Log() << kERROR<<
Form(
"Dataset[%s] : ",
DataInfo().
GetName())<<
"<CreateMVAPdfs> No result of classifier testing available" <<
Endl;
2146 histMVAPdfS->Sumw2();
2147 histMVAPdfB->
Sumw2();
2155 else histMVAPdfB->
Fill( theVal, theWeight );
2164 histMVAPdfS->Write();
2165 histMVAPdfB->
Write();
2173 if (
DataInfo().GetNClasses() == 2) {
2175 <<
Form(
"<CreateMVAPdfs> Separation from histogram (PDF): %1.3f (%1.3f)",
2189 Log() << kINFO<<
Form(
"Dataset[%s] : ",
DataInfo().
GetName()) <<
"<GetProba> MVA PDFs for Signal and Background don't exist yet, we'll create them on demand" <<
Endl;
2195 return GetProba(mvaVal,sigFraction);
2204 Log() << kWARNING <<
Form(
"Dataset[%s] : ",
DataInfo().
GetName())<<
"<GetProba> MVA PDFs for Signal and Background don't exist" <<
Endl;
2210 Double_t denom = p_s*ap_sig + p_b*(1 - ap_sig);
2212 return (denom > 0) ? (p_s*ap_sig) / denom : -1;
2225 Log() << kWARNING <<
Form(
"Dataset[%s] : ",
DataInfo().
GetName())<<
"<GetRarity> Required MVA PDF for Signal or Background does not exist: " 2226 <<
"select option \"CreateMVAPdfs\"" <<
Endl;
2251 else if (list->
GetSize() > 2) {
2252 Log() << kFATAL <<
Form(
"Dataset[%s] : ",
DataInfo().
GetName())<<
"<GetEfficiency> Wrong number of arguments" 2253 <<
" in string: " << theString
2254 <<
" | required format, e.g., Efficiency:0.05, or empty string" <<
Endl;
2262 Log() << kFATAL <<
Form(
"Dataset[%s] : ",
DataInfo().
GetName())<<
"<GetEfficiency> Binning mismatch between signal and background histos" <<
Endl;
2270 TH1 * effhist = results->
GetHist(
"MVA_HIGHBIN_S");
2277 if (results->
DoesExist(
"MVA_EFF_S")==0) {
2282 results->
Store(eff_s,
"MVA_EFF_S");
2283 results->
Store(eff_b,
"MVA_EFF_B");
2295 Float_t theVal = (*mvaRes)[ievt];
2298 TH1* theHist = isSignal ? eff_s : eff_b;
2301 if (isSignal) nevtS+=theWeight;
2305 if (sign > 0 && maxbin >
fNbinsH)
continue;
2306 if (sign < 0 && maxbin < 1 )
continue;
2307 if (sign > 0 && maxbin < 1 ) maxbin = 1;
2327 results->
Store(eff_BvsS,
"MVA_EFF_BvsS");
2333 results->
Store(rej_BvsS);
2335 rej_BvsS->
SetYTitle(
"Backgr rejection (1-eff)" );
2340 results->
Store(inveff_BvsS);
2342 inveff_BvsS->
SetYTitle(
"Inverse backgr. eff (1/eff)" );
2385 Double_t effS = 0., rejB, effS_ = 0., rejB_ = 0.;
2386 Int_t nbins_ = 5000;
2387 for (
Int_t bini=1; bini<=nbins_; bini++) {
2390 effS = (bini - 0.5)/
Float_t(nbins_);
2394 if ((effS - rejB)*(effS_ - rejB_) < 0)
break;
2412 Double_t effS = 0, effB = 0, effS_ = 0, effB_ = 0;
2413 Int_t nbins_ = 1000;
2419 for (
Int_t bini=1; bini<=nbins_; bini++) {
2422 effS = (bini - 0.5)/
Float_t(nbins_);
2424 integral += (1.0 - effB);
2438 for (
Int_t bini=1; bini<=nbins_; bini++) {
2441 effS = (bini - 0.5)/
Float_t(nbins_);
2445 if ((effB - effBref)*(effB_ - effBref) <= 0)
break;
2451 effS = 0.5*(effS + effS_);
2454 if (nevtS > 0) effSerr =
TMath::Sqrt( effS*(1.0 - effS)/nevtS );
2479 Log() << kFATAL <<
Form(
"Dataset[%s] : ",
DataInfo().
GetName())<<
"<GetTrainingEfficiency> Wrong number of arguments" 2480 <<
" in string: " << theString
2481 <<
" | required format, e.g., Efficiency:0.05" <<
Endl;
2494 Log() << kFATAL <<
Form(
"Dataset[%s] : ",
DataInfo().
GetName())<<
"<GetTrainingEfficiency> Binning mismatch between signal and background histos" 2502 TH1 * effhist = results->
GetHist(
"MVA_HIGHBIN_S");
2507 if (results->
DoesExist(
"MVA_TRAIN_S")==0) {
2515 results->
Store(mva_s_tr,
"MVA_TRAIN_S");
2516 results->
Store(mva_b_tr,
"MVA_TRAIN_B");
2525 results->
Store(mva_eff_tr_s,
"MVA_TRAINEFF_S");
2526 results->
Store(mva_eff_tr_b,
"MVA_TRAINEFF_B");
2546 theClsHist->
Fill( theVal, theWeight );
2550 if (sign > 0 && maxbin >
fNbinsH)
continue;
2551 if (sign < 0 && maxbin < 1 )
continue;
2552 if (sign > 0 && maxbin < 1 ) maxbin = 1;
2555 if (sign > 0)
for (
Int_t ibin=1; ibin<=maxbin; ibin++) theEffHist->
AddBinContent( ibin , theWeight );
2572 results->
Store(eff_bvss,
"EFF_BVSS_TR");
2573 results->
Store(rej_bvss,
"REJ_BVSS_TR");
2621 Double_t effS = 0., effB, effS_ = 0., effB_ = 0.;
2622 Int_t nbins_ = 1000;
2623 for (
Int_t bini=1; bini<=nbins_; bini++) {
2626 effS = (bini - 0.5)/
Float_t(nbins_);
2630 if ((effB - effBref)*(effB_ - effBref) <= 0)
break;
2635 return 0.5*(effS + effS_);
2644 if (!resMulticlass)
Log() << kFATAL<<
Form(
"Dataset[%s] : ",
DataInfo().
GetName())<<
"unable to create pointer in GetMulticlassEfficiency, exiting."<<
Endl;
2656 if (!resMulticlass)
Log() << kFATAL<<
"unable to create pointer in GetMulticlassTrainingEfficiency, exiting."<<
Endl;
2658 Log() << kINFO <<
Form(
"Dataset[%s] : ",
DataInfo().
GetName())<<
"Determine optimal multiclass cuts for training data..." <<
Endl;
2690 Log() << kFATAL <<
"Cannot get confusion matrix for non-multiclass analysis." << std::endl;
2698 if (resMulticlass ==
nullptr) {
2700 <<
"unable to create pointer in GetMulticlassEfficiency, exiting." <<
Endl;
2741 if ((!pdfS && pdfB) || (pdfS && !pdfB))
2743 if (!pdfS) pdfS =
fSplS;
2744 if (!pdfB) pdfB =
fSplB;
2747 Log()<<kDEBUG<<
Form(
"[%s] : ",
DataInfo().
GetName())<<
"could not calculate the separation, distributions" 2748 <<
" fSplS or fSplB are not yet filled" <<
Endl;
2763 if ((!histS && histB) || (histS && !histB))
2766 if (histS==0 || histB==0)
return 0.;
2779 for (
UInt_t i=0; i<nsteps; i++) {
2783 return integral*step;
2795 if ((!pdfS && pdfB) || (pdfS && !pdfB))
2797 if (!pdfS) pdfS =
fSplS;
2798 if (!pdfB) pdfB =
fSplB;
2800 if (pdfS==0 || pdfB==0)
return 0.;
2809 for (
UInt_t i=0; i<nsteps; i++) {
2813 return integral*step;
2823 Double_t& max_significance_value )
const 2828 Double_t effS(0),effB(0),significance(0);
2831 if (SignalEvents <= 0 || BackgroundEvents <= 0) {
2833 <<
"Number of signal or background events is <= 0 ==> abort" 2837 Log() << kINFO <<
Form(
"Dataset[%s] : ",
DataInfo().
GetName())<<
"Using ratio SignalEvents/BackgroundEvents = " 2838 << SignalEvents/BackgroundEvents <<
Endl;
2843 if ( (eff_s==0) || (eff_b==0) ) {
2854 significance =
sqrt(SignalEvents)*( effS )/
sqrt( effS + ( BackgroundEvents / SignalEvents) * effB );
2864 delete temp_histogram;
2869 return max_significance;
2889 Log() << kFATAL <<
Form(
"Dataset[%s] : ",
DataInfo().
GetName())<<
"<CalculateEstimator> Wrong tree type: " << treeType <<
Endl;
2908 for (
Int_t ievt = 0; ievt < entries; ievt++) {
2917 meanS += weight*theVar;
2918 rmsS += weight*theVar*theVar;
2922 meanB += weight*theVar;
2923 rmsB += weight*theVar*theVar;
2931 meanS = meanS/sumwS;
2932 meanB = meanB/sumwB;
2946 if (theClassFileName ==
"")
2949 classFileName = theClassFileName;
2953 TString tfname( classFileName );
2955 <<
"Creating standalone class: " 2958 std::ofstream fout( classFileName );
2960 Log() << kFATAL <<
"<MakeClass> Unable to open file: " << classFileName <<
Endl;
2965 fout <<
"// Class: " << className << std::endl;
2966 fout <<
"// Automatically generated by MethodBase::MakeClass" << std::endl <<
"//" << std::endl;
2970 fout <<
"/* configuration options =====================================================" << std::endl << std::endl;
2973 fout <<
"============================================================================ */" << std::endl;
2976 fout <<
"" << std::endl;
2977 fout <<
"#include <array>" << std::endl;
2978 fout <<
"#include <vector>" << std::endl;
2979 fout <<
"#include <cmath>" << std::endl;
2980 fout <<
"#include <string>" << std::endl;
2981 fout <<
"#include <iostream>" << std::endl;
2982 fout <<
"" << std::endl;
2987 fout <<
"#ifndef IClassifierReader__def" << std::endl;
2988 fout <<
"#define IClassifierReader__def" << std::endl;
2990 fout <<
"class IClassifierReader {" << std::endl;
2992 fout <<
" public:" << std::endl;
2994 fout <<
" // constructor" << std::endl;
2995 fout <<
" IClassifierReader() : fStatusIsClean( true ) {}" << std::endl;
2996 fout <<
" virtual ~IClassifierReader() {}" << std::endl;
2998 fout <<
" // return classifier response" << std::endl;
2999 fout <<
" virtual double GetMvaValue( const std::vector<double>& inputValues ) const = 0;" << std::endl;
3001 fout <<
" // returns classifier status" << std::endl;
3002 fout <<
" bool IsStatusClean() const { return fStatusIsClean; }" << std::endl;
3004 fout <<
" protected:" << std::endl;
3006 fout <<
" bool fStatusIsClean;" << std::endl;
3007 fout <<
"};" << std::endl;
3009 fout <<
"#endif" << std::endl;
3011 fout <<
"class " << className <<
" : public IClassifierReader {" << std::endl;
3013 fout <<
" public:" << std::endl;
3015 fout <<
" // constructor" << std::endl;
3016 fout <<
" " << className <<
"( std::vector<std::string>& theInputVars ) " << std::endl;
3017 fout <<
" : IClassifierReader()," << std::endl;
3018 fout <<
" fClassName( \"" << className <<
"\" )," << std::endl;
3019 fout <<
" fNvars( " <<
GetNvar() <<
" )," << std::endl;
3020 fout <<
" fIsNormalised( " << (
IsNormalised() ?
"true" :
"false") <<
" )" << std::endl;
3021 fout <<
" { " << std::endl;
3022 fout <<
" // the training input variables" << std::endl;
3023 fout <<
" const char* inputVars[] = { ";
3026 if (ivar<
GetNvar()-1) fout <<
", ";
3028 fout <<
" };" << std::endl;
3030 fout <<
" // sanity checks" << std::endl;
3031 fout <<
" if (theInputVars.size() <= 0) {" << std::endl;
3032 fout <<
" std::cout << \"Problem in class \\\"\" << fClassName << \"\\\": empty input vector\" << std::endl;" << std::endl;
3033 fout <<
" fStatusIsClean = false;" << std::endl;
3034 fout <<
" }" << std::endl;
3036 fout <<
" if (theInputVars.size() != fNvars) {" << std::endl;
3037 fout <<
" std::cout << \"Problem in class \\\"\" << fClassName << \"\\\": mismatch in number of input values: \"" << std::endl;
3038 fout <<
" << theInputVars.size() << \" != \" << fNvars << std::endl;" << std::endl;
3039 fout <<
" fStatusIsClean = false;" << std::endl;
3040 fout <<
" }" << std::endl;
3042 fout <<
" // validate input variables" << std::endl;
3043 fout <<
" for (size_t ivar = 0; ivar < theInputVars.size(); ivar++) {" << std::endl;
3044 fout <<
" if (theInputVars[ivar] != inputVars[ivar]) {" << std::endl;
3045 fout <<
" std::cout << \"Problem in class \\\"\" << fClassName << \"\\\": mismatch in input variable names\" << std::endl" << std::endl;
3046 fout <<
" << \" for variable [\" << ivar << \"]: \" << theInputVars[ivar].c_str() << \" != \" << inputVars[ivar] << std::endl;" << std::endl;
3047 fout <<
" fStatusIsClean = false;" << std::endl;
3048 fout <<
" }" << std::endl;
3049 fout <<
" }" << std::endl;
3051 fout <<
" // initialize min and max vectors (for normalisation)" << std::endl;
3053 fout <<
" fVmin[" << ivar <<
"] = " << std::setprecision(15) <<
GetXmin( ivar ) <<
";" << std::endl;
3054 fout <<
" fVmax[" << ivar <<
"] = " << std::setprecision(15) <<
GetXmax( ivar ) <<
";" << std::endl;
3057 fout <<
" // initialize input variable types" << std::endl;
3062 fout <<
" // initialize constants" << std::endl;
3063 fout <<
" Initialize();" << std::endl;
3066 fout <<
" // initialize transformation" << std::endl;
3067 fout <<
" InitTransform();" << std::endl;
3069 fout <<
" }" << std::endl;
3071 fout <<
" // destructor" << std::endl;
3072 fout <<
" virtual ~" << className <<
"() {" << std::endl;
3073 fout <<
" Clear(); // method-specific" << std::endl;
3074 fout <<
" }" << std::endl;
3076 fout <<
" // the classifier response" << std::endl;
3077 fout <<
" // \"inputValues\" is a vector of input values in the same order as the " << std::endl;
3078 fout <<
" // variables given to the constructor" << std::endl;
3079 fout <<
" double GetMvaValue( const std::vector<double>& inputValues ) const;" << std::endl;
3081 fout <<
" private:" << std::endl;
3083 fout <<
" // method-specific destructor" << std::endl;
3084 fout <<
" void Clear();" << std::endl;
3087 fout <<
" // input variable transformation" << std::endl;
3089 fout <<
" void InitTransform();" << std::endl;
3090 fout <<
" void Transform( std::vector<double> & iv, int sigOrBgd ) const;" << std::endl;
3093 fout <<
" // common member variables" << std::endl;
3094 fout <<
" const char* fClassName;" << std::endl;
3096 fout <<
" const size_t fNvars;" << std::endl;
3097 fout <<
" size_t GetNvar() const { return fNvars; }" << std::endl;
3098 fout <<
" char GetType( int ivar ) const { return fType[ivar]; }" << std::endl;
3100 fout <<
" // normalisation of input variables" << std::endl;
3101 fout <<
" const bool fIsNormalised;" << std::endl;
3102 fout <<
" bool IsNormalised() const { return fIsNormalised; }" << std::endl;
3103 fout <<
" double fVmin[" <<
GetNvar() <<
"];" << std::endl;
3104 fout <<
" double fVmax[" <<
GetNvar() <<
"];" << std::endl;
3105 fout <<
" double NormVariable( double x, double xmin, double xmax ) const {" << std::endl;
3106 fout <<
" // normalise to output range: [-1, 1]" << std::endl;
3107 fout <<
" return 2*(x - xmin)/(xmax - xmin) - 1.0;" << std::endl;
3108 fout <<
" }" << std::endl;
3110 fout <<
" // type of input variable: 'F' or 'I'" << std::endl;
3111 fout <<
" char fType[" <<
GetNvar() <<
"];" << std::endl;
3113 fout <<
" // initialize internal variables" << std::endl;
3114 fout <<
" void Initialize();" << std::endl;
3115 fout <<
" double GetMvaValue__( const std::vector<double>& inputValues ) const;" << std::endl;
3116 fout <<
"" << std::endl;
3117 fout <<
" // private members (method specific)" << std::endl;
3122 fout <<
" inline double " << className <<
"::GetMvaValue( const std::vector<double>& inputValues ) const" << std::endl;
3123 fout <<
" {" << std::endl;
3124 fout <<
" // classifier response value" << std::endl;
3125 fout <<
" double retval = 0;" << std::endl;
3127 fout <<
" // classifier response, sanity check first" << std::endl;
3128 fout <<
" if (!IsStatusClean()) {" << std::endl;
3129 fout <<
" std::cout << \"Problem in class \\\"\" << fClassName << \"\\\": cannot return classifier response\"" << std::endl;
3130 fout <<
" << \" because status is dirty\" << std::endl;" << std::endl;
3131 fout <<
" retval = 0;" << std::endl;
3132 fout <<
" }" << std::endl;
3133 fout <<
" else {" << std::endl;
3134 fout <<
" if (IsNormalised()) {" << std::endl;
3135 fout <<
" // normalise variables" << std::endl;
3136 fout <<
" std::vector<double> iV;" << std::endl;
3137 fout <<
" iV.reserve(inputValues.size());" << std::endl;
3138 fout <<
" int ivar = 0;" << std::endl;
3139 fout <<
" for (std::vector<double>::const_iterator varIt = inputValues.begin();" << std::endl;
3140 fout <<
" varIt != inputValues.end(); varIt++, ivar++) {" << std::endl;
3141 fout <<
" iV.push_back(NormVariable( *varIt, fVmin[ivar], fVmax[ivar] ));" << std::endl;
3142 fout <<
" }" << std::endl;
3146 fout <<
" Transform( iV, -1 );" << std::endl;
3148 fout <<
" retval = GetMvaValue__( iV );" << std::endl;
3149 fout <<
" }" << std::endl;
3150 fout <<
" else {" << std::endl;
3154 fout <<
" std::vector<double> iV;" << std::endl;
3155 fout <<
" int ivar = 0;" << std::endl;
3156 fout <<
" for (std::vector<double>::const_iterator varIt = inputValues.begin();" << std::endl;
3157 fout <<
" varIt != inputValues.end(); varIt++, ivar++) {" << std::endl;
3158 fout <<
" iV.push_back(*varIt);" << std::endl;
3159 fout <<
" }" << std::endl;
3160 fout <<
" Transform( iV, -1 );" << std::endl;
3161 fout <<
" retval = GetMvaValue__( iV );" << std::endl;
3164 fout <<
" retval = GetMvaValue__( inputValues );" << std::endl;
3166 fout <<
" }" << std::endl;
3167 fout <<
" }" << std::endl;
3169 fout <<
" return retval;" << std::endl;
3170 fout <<
" }" << std::endl;
3186 std::streambuf* cout_sbuf = std::cout.rdbuf();
3187 std::ofstream* o = 0;
3188 if (
gConfig().WriteOptionsReference()) {
3194 std::cout.rdbuf( o->rdbuf() );
3201 <<
"================================================================" 3205 <<
"H e l p f o r M V A m e t h o d [ " <<
GetName() <<
" ] :" 3210 Log() <<
"Help for MVA method [ " <<
GetName() <<
" ] :" <<
Endl;
3218 Log() <<
"<Suppress this message by specifying \"!H\" in the booking option>" <<
Endl;
3220 <<
"================================================================" 3227 Log() <<
"# End of Message___" <<
Endl;
3230 std::cout.rdbuf( cout_sbuf );
3315 if (mvaRes != NULL) {
3318 TH1D *mva_s_tr =
dynamic_cast<TH1D*
> (mvaRes->
GetHist(
"MVA_TRAIN_S"));
3319 TH1D *mva_b_tr =
dynamic_cast<TH1D*
> (mvaRes->
GetHist(
"MVA_TRAIN_B"));
3321 if ( !mva_s || !mva_b || !mva_s_tr || !mva_b_tr)
return -1;
3323 if (SorB ==
's' || SorB ==
'S')
virtual void DeclareOptions()=0
Bool_t HasMVAPdfs() const
Types::EAnalysisType fAnalysisType
virtual const char * GetName() const
Returns name of object.
virtual Int_t Write(const char *name=0, Int_t option=0, Int_t bufsize=0)
Write this object to the current directory.
virtual void AddClassifierOutputProb(Types::ETreeType type)
prepare tree branch with the method's discriminating variable
virtual Int_t FindBin(Double_t x, Double_t y=0, Double_t z=0)
Return Global bin number corresponding to x,y,z.
virtual void Scale(Double_t c1=1, Option_t *option="")
Multiply this histogram by a constant c1.
virtual Int_t Fill(Double_t x)
Increment bin with abscissa X by 1.
void WriteStateToXML(void *parent) const
general method used in writing the header of the weight files where the used variables, variable transformation type etc.
virtual void SetTuneParameters(std::map< TString, Double_t > tuneParameters)
set the tuning parameters according to the argument This is just a dummy .
virtual void MakeClass(const TString &classFileName=TString("")) const
create reader class for method (classification only at present)
virtual Double_t GetMaximum(Double_t maxval=FLT_MAX) const
Return maximum value smaller than maxval of bins in the range, unless the value has been overridden b...
UInt_t GetNVariables() const
virtual Double_t GetBinCenter(Int_t bin) const
Return bin center for 1D histogram.
virtual const std::vector< Float_t > & GetMulticlassValues()
#define TMVA_VERSION_CODE
void SetCurrentEvent(Long64_t ievt) const
MsgLogger & Endl(MsgLogger &ml)
Bool_t GetLine(std::istream &fin, char *buf)
reads one line from the input stream checks for certain keywords and interprets the line if keywords ...
void ReadOptionsFromXML(void *node)
void ReadXML(void *pdfnode)
XML file reading.
Singleton class for Global types used by TMVA.
void AddOutput(Types::ETreeType type, Types::EAnalysisType analysisType)
VariableInfo & AddTarget(const TString &expression, const TString &title, const TString &unit, Double_t min, Double_t max, Bool_t normalized=kTRUE, void *external=0)
add a variable (can be a complex expression) to the set of variables used in the MV analysis ...
Class that is the base-class for a vector of result.
void AddPoint(Double_t x, Double_t y1, Double_t y2)
This function is used only in 2 TGraph case, and it will add new data points to graphs.
Bool_t fIgnoreNegWeightsInTraining
virtual const char * WorkingDirectory()
Return working directory.
void ReadStateFromXML(void *parent)
std::vector< VariableInfo > & GetSpectatorInfos()
void WriteVarsToStream(std::ostream &tf, const TString &prefix="") const
write the list of variables (name, min, max) for a given data transformation method to the stream ...
virtual Double_t GetMvaValue(Double_t *errLower=0, Double_t *errUpper=0)=0
virtual void MakeClassSpecificHeader(std::ostream &, const TString &="") const
Collectable string class.
virtual Double_t GetValueForRoot(Double_t)
returns efficiency as function of cut
std::vector< TGraph * > fGraphs
void ReadOptionsFromStream(std::istream &istr)
read option back from the weight file
TString & ReplaceAll(const TString &s1, const TString &s2)
TH1 * GetSmoothedHist() const
virtual const char * GetBuildNode() const
Return the build node name.
void BuildPDF(const TH1 *theHist)
virtual void WriteEvaluationHistosToFile(Types::ETreeType treetype)
writes all MVA evaluation histograms to file
const TString & GetOriginalVarName(Int_t ivar) const
virtual std::map< TString, Double_t > OptimizeTuningParameters(TString fomType="ROCIntegral", TString fitType="FitGA")
call the Optimizer with the set of parameters and ranges that are meant to be tuned.
TString fVariableTransformTypeString
XMLDocPointer_t NewDoc(const char *version="1.0")
creates new xml document with provided version
OptionBase * DeclareOptionRef(T &ref, const TString &name, const TString &desc="")
TransformationHandler * fTransformationPointer
Types::ESBType fVariableTransformType
virtual Double_t GetBinContent(Int_t bin) const
Return content of bin number bin.
A ROOT file is a suite of consecutive data records (TKey instances) with a well defined format...
virtual Double_t Eval(Double_t x) const
returns linearly interpolated TGraph entry around x
A TMultiGraph is a collection of TGraph (or derived) objects.
virtual Int_t GetQuantiles(Int_t nprobSum, Double_t *q, const Double_t *probSum=0)
Compute Quantiles for this histogram Quantile x_q of a probability distribution Function F is defined...
virtual int MakeDirectory(const char *name)
Make a directory.
Virtual base Class for all MVA method.
virtual TObject * Get(const char *namecycle)
Return pointer to object identified by namecycle.
virtual Double_t GetMean(Int_t axis=1) const
For axis = 1,2 or 3 returns the mean value of the histogram along X,Y or Z axis.
Ssiz_t Index(const char *pat, Ssiz_t i=0, ECaseCompare cmp=kExact) const
virtual const std::vector< Float_t > & GetRegressionValues()
const TString & GetReferenceFile() const
static Bool_t AddDirectoryStatus()
Static function: cannot be inlined on Windows/NT.
1-D histogram with a float per channel (see TH1 documentation)}
void SetTrainTime(Double_t trainTime)
TMultiGraph * fMultiGraph
TransformationHandler & GetTransformationHandler(Bool_t takeReroutedIfAvailable=true)
Short_t Min(Short_t a, Short_t b)
void ToLower()
Change string to lower-case.
virtual Double_t GetKSTrainingVsTest(Char_t SorB, TString opt="X")
virtual void SetYTitle(const char *title)
virtual TDirectory * mkdir(const char *name, const char *title="")
Create a sub-directory "a" or a hierarchy of sub-directories "a/b/c/...".
virtual void TestMulticlass()
test multiclass classification
TString GetTrainingROOTVersionString() const
calculates the ROOT version string from the training version code on the fly
UInt_t GetNClasses() const
UInt_t GetNTargets() const
TMatrixD GetConfusionMatrix(Double_t effB)
Returns a confusion matrix where each class is pitted against each other.
const std::vector< Event * > & GetEventCollection(Types::ETreeType type=Types::kMaxTreeType) const
std::vector< TString > * fInputVars
virtual void GetRegressionDeviation(UInt_t tgtNum, Types::ETreeType type, Double_t &stddev, Double_t &stddev90Percent) const
#define ROOT_VERSION_CODE
void ReadTargetsFromXML(void *tarnode)
read target info from XML
virtual Double_t GetMaximumSignificance(Double_t SignalEvents, Double_t BackgroundEvents, Double_t &optimal_significance_value) const
plot significance, , curve for given number of signal and background events; returns cut for maximum ...
void AddInfoItem(void *gi, const TString &name, const TString &value) const
xml writing
virtual Double_t GetROCIntegral(TH1D *histS, TH1D *histB) const
calculate the area (integral) under the ROC curve as a overall quality measure of the classification ...
TDirectory * MethodBaseDir() const
returns the ROOT directory where all instances of the corresponding MVA method are stored ...
Double_t GetTrainingSumSignalWeights()
void FreeDoc(XMLDocPointer_t xmldoc)
frees allocated document data and deletes document itself
Double_t GetTrainTime() const
virtual Bool_t IsSignalLike()
uses a pre-set cut on the MVA output (SetSignalReferenceCut and SetSignalReferenceCutOrientation) for...
void CreateMVAPdfs()
Create PDFs of the MVA output variables.
static void AddDirectory(Bool_t add=kTRUE)
Sets the flag controlling the automatic add of histograms in memory.
void ReadVariablesFromXML(void *varnode)
read variable info from XML
const TString & GetExpression() const
static TFile * Open(const char *name, Option_t *option="", const char *ftitle="", Int_t compress=1, Int_t netopt=0)
Create / open a file.
const TString & GetWeightFileDir() const
void WriteStateToFile() const
write options and weights to file note that each one text file for the main configuration information...
static void SetIsTraining(Bool_t)
when this static function is called, it sets the flag whether events with negative event weight shoul...
Class that contains all the information of a class.
TString GetTrainingTMVAVersionString() const
calculates the TMVA version string from the training version code on the fly
DataSetInfo & fDataSetInfo
UInt_t TreeIndex(Types::ETreeType type) const
static TString Format(const char *fmt,...)
Static method which formats a string using a printf style format descriptor and return a TString...
ECutOrientation fCutOrientation
virtual ~MethodBase()
destructor
void DocSetRootElement(XMLDocPointer_t xmldoc, XMLNodePointer_t xmlnode)
set main (root) node for document
UInt_t GetTrainingTMVAVersionCode() const
virtual std::vector< Double_t > GetMvaValues(Long64_t firstEvt=0, Long64_t lastEvt=-1, Bool_t logProgress=false)
get all the MVA values for the events of the current Data type
const Event * GetEvent() const
MethodBase(const TString &jobName, Types::EMVA methodType, const TString &methodTitle, DataSetInfo &dsi, const TString &theOption="")
standard constructor
void ClearGraphs()
This function sets the point number to 0 for all graphs.
void ReadStateFromFile()
Function to write options and weights to file.
Types::ETreeType GetCurrentType() const
std::vector< Float_t > * GetValueVector()
~IPythonInteractive()
standard destructor
virtual void AddClassifierOutput(Types::ETreeType type)
prepare tree branch with the method's discriminating variable
virtual Double_t GetRarity(Double_t mvaVal, Types::ESBType reftype=Types::kBackground) const
compute rarity: where PDF(x) is the PDF of the classifier's signal or background distribution ...
void PrintHelpMessage() const
prints out method-specific help method
void ReadClassesFromXML(void *clsnode)
read number of classes from XML
Bool_t EndsWith(const char *pat, ECaseCompare cmp=kExact) const
Return true if string ends with the specified string.
virtual void ParseOptions()
options parser
Double_t GetXmin(Int_t ivar) const
void SetupMethod()
setup of methods
void Init(std::vector< TString > &graphTitles)
This function gets some title and it creates a TGraph for every title.
DataSetInfo & DataInfo() const
void SetOptions(const TString &s)
virtual UserGroup_t * GetUserInfo(Int_t uid)
Returns all user info in the UserGroup_t structure.
Bool_t DoRegression() const
XMLDocPointer_t ParseString(const char *xmlstring)
parses content of string and tries to produce xml structures
void SetMinType(EMsgType minType)
Ssiz_t First(char c) const
Find first occurrence of a character c.
Bool_t DoesExist(const TString &alias) const
Class that contains all the data information.
virtual void ProcessOptions()=0
virtual Double_t GetProba(const Event *ev)
PDF wrapper for histograms; uses user-defined spline interpolation.
virtual void AddBinContent(Int_t bin)
Increment bin content by 1.
Double_t GetWeight() const
return the event weight - depending on whether the flag IgnoreNegWeightsInTraining is or not...
Long64_t GetNTrainingEvents() const
std::vector< VariableInfo > & GetTargetInfos()
virtual Double_t GetEfficiency(const TString &, Types::ETreeType, Double_t &err)
fill background efficiency (resp.
void CreateVariableTransforms(const TString &trafoDefinition, TMVA::DataSetInfo &dataInfo, TMVA::TransformationHandler &transformationHandler, TMVA::MsgLogger &log)
virtual std::vector< Float_t > GetMulticlassEfficiency(std::vector< std::vector< Float_t > > &purity)
Double_t Root(Double_t refValue)
Root finding using Brents algorithm; taken from CERNLIB function RZERO.
virtual void AddWeightsXMLTo(void *parent) const =0
UInt_t fTMVATrainingVersion
UInt_t GetNEvents() const
temporary event when testing on a different DataSet than the own one
TString GetElapsedTime(Bool_t Scientific=kTRUE)
returns pretty string with elapsed time
Double_t GetXmax(Int_t ivar) const
TransformationHandler fTransformation
TMatrixT< Double_t > TMatrixD
void ReadStateFromXMLString(const char *xmlstr)
for reading from memory
Bool_t DoMulticlass() const
virtual Double_t KolmogorovTest(const TH1 *h2, Option_t *option="") const
Statistical test of compatibility in shape between this histogram and h2, using Kolmogorov test...
virtual void MakeClassSpecific(std::ostream &, const TString &="") const
virtual void ReadWeightsFromXML(void *wghtnode)=0
Int_t GetHistNBins(Int_t evtNum=0)
void SaveDoc(XMLDocPointer_t xmldoc, const char *filename, Int_t layout=1)
store document content to file if layout<=0, no any spaces or newlines will be placed between xmlnode...
TString fWeightFileExtension
void * GetExternalLink() const
Float_t GetTarget(UInt_t itgt) const
void WriteStateToStream(std::ostream &tf) const
general method used in writing the header of the weight files where the used variables, variable transformation type etc.
Results * GetResults(const TString &, Types::ETreeType type, Types::EAnalysisType analysistype)
Class to manage histogram axis.
R__EXTERN TSystem * gSystem
TDirectory * fMethodBaseDir
UInt_t fROOTTrainingVersion
const char * GetName() const
ClassInfo * GetClassInfo(Int_t clNum) const
void ReadVarsFromStream(std::istream &istr)
Read the variables (name, min, max) for a given data transformation method from the stream...
void AddClassesXMLTo(void *parent) const
write class info to XML
const Int_t NBIN_HIST_HIGH
2-D histogram with a float per channel (see TH1 documentation)}
class TMVA::Config::VariablePlotting fVariablePlotting
void Statistics(Types::ETreeType treeType, const TString &theVarName, Double_t &, Double_t &, Double_t &, Double_t &, Double_t &, Double_t &)
calculates rms,mean, xmin, xmax of the event variable this can be either done for the variables as th...
Bool_t BeginsWith(const char *s, ECaseCompare cmp=kExact) const
virtual void SetBinContent(Int_t bin, Double_t content)
Set bin content see convention for numbering bins in TH1::GetBin In case the bin number is greater th...
Float_t GetAchievablePur(UInt_t cls)
void SetReadingVersion(UInt_t rv)
void SetValue(Float_t value, Int_t ievt)
set MVA response
UInt_t GetTrainingROOTVersionCode() const
Double_t ElapsedSeconds(void)
computes elapsed tim in seconds
char * Form(const char *fmt,...)
void ReadFromXML(void *varnode)
read VariableInfo from stream
TSubString Strip(EStripType s=kTrailing, char c=' ') const
Return a substring of self stripped at beginning and/or end.
const TString & GetJobName() const
const TString & GetMethodName() const
UInt_t GetNSpectators(bool all=kTRUE) const
virtual Double_t Eval(Double_t x) const =0
TSpline * fSplTrainEffBvsS
static constexpr double m2
virtual TObject * At(Int_t idx) const
Returns the object at position idx. Returns 0 if idx is out of range.
void DeclareBaseOptions()
define the options (their key words) that can be set in the option string here the options valid for ...
1-D histogram with a double per channel (see TH1 documentation)}
virtual Double_t GetSignificance() const
compute significance of mean difference
TString GetWeightFileName() const
retrieve weight file name
Linear interpolation of TGraph.
Double_t GetSignalReferenceCutOrientation() const
void ProcessBaseOptions()
the option string is decoded, for available options see "DeclareOptions"
Int_t FindVarIndex(const TString &) const
find variable by name
UInt_t GetNVariables() const
std::vector< const std::vector< TMVA::Event * > * > fEventCollections
void AddSpectatorsXMLTo(void *parent) const
write spectator info to XML
Float_t GetValue(UInt_t ivar) const
return value of i'th variable
TString fVerbosityLevelString
void DeclareOptions()
define the options (their key words) that can be set in the option string
TList * GetStorage() const
static void SetIgnoreNegWeightsInTraining(Bool_t)
when this static function is called, it sets the flag whether events with negative event weight shoul...
XMLDocPointer_t ParseFile(const char *filename, Int_t maxbuf=100000)
Parses content of file and tries to produce xml structures.
const std::vector< TMVA::Event * > & GetEventCollection(Types::ETreeType type)
returns the event collection (i.e.
virtual void CheckSetup()
check may be overridden by derived class (sometimes, eg, fitters are used which can only be implement...
void SetTestTime(Double_t testTime)
virtual void AddRegressionOutput(Types::ETreeType type)
prepare tree branch with the method's discriminating variable
std::vector< Double_t > GetBestMultiClassCuts(UInt_t targetClass)
calculate the best working point (optimal cut values) for the multiclass classifier ...
void SetWeightFileName(TString)
set the weight file name (depreciated)
virtual Double_t GetSeparation(TH1 *, TH1 *) const
compute "separation" defined as
Describe directory structure in memory.
std::vector< Float_t > * fMulticlassReturnVal
Bool_t IsNormalised() const
Double_t GetTrainingSumBackgrWeights()
TH1 * GetHist(const TString &alias) const
Class which takes the results of a multiclass classification.
static RooMathCoreReg dummy
virtual void GetHelpMessage() const =0
void SetCurrentType(Types::ETreeType type) const
void AddVarsXMLTo(void *parent) const
write variable info to XML
Bool_t Contains(const char *pat, ECaseCompare cmp=kExact) const
const Bool_t Use_Splines_for_Eff_
static constexpr double s
const char * AsString() const
Return the date & time as a string (ctime() format).
VariableInfo & GetVariableInfo(Int_t i)
void AddPreDefVal(const T &)
IPythonInteractive()
standard constructor
virtual void WriteMonitoringHistosToFile() const
write special monitoring histograms to file dummy implementation here --------------— ...
ClassInfo * AddClass(const TString &className)
void AddXMLTo(void *parent)
XML file writing.
Bool_t fConstructedFromWeightFile
virtual const char * GetName() const
Returns name of object.
void ProcessSetup()
process all options the "CheckForUnusedOptions" is done in an independent call, since it may be overr...
TString fVarTransformString
virtual void AddMulticlassOutput(Types::ETreeType type)
prepare tree branch with the method's discriminating variable
const TString & GetOptions() const
void SetConfigName(const char *n)
Interface for all concrete MVA method implementations.
void ValidatePDF(TH1 *original=0) const
comparison of original histogram with reference PDF
Float_t GetAchievableEff(UInt_t cls)
void SetSource(const std::string &source)
Root finding using Brents algorithm (translated from CERNLIB function RZERO)
virtual std::vector< Float_t > GetMulticlassTrainingEfficiency(std::vector< std::vector< Float_t > > &purity)
virtual void SetXTitle(const char *title)
virtual void TestRegression(Double_t &bias, Double_t &biasT, Double_t &dev, Double_t &devT, Double_t &rms, Double_t &rmsT, Double_t &mInf, Double_t &mInfT, Double_t &corr, Types::ETreeType type)
calculate <sum-of-deviation-squared> of regression output versus "true" value from test sample ...
virtual Bool_t cd(const char *path=0)
Change current directory to "this" directory.
void ReadFromStream(std::istream &istr)
read VariableInfo from stream
TDirectory * BaseDir() const
returns the ROOT directory where info/histograms etc of the corresponding MVA method instance are sto...
TString GetMethodTypeName() const
virtual void DeclareCompatibilityOptions()
options that are used ONLY for the READER to ensure backward compatibility they are hence without any...
Class that is the base-class for a vector of result.
Short_t Max(Short_t a, Short_t b)
void AddToXML(void *varnode)
write class to XML
Double_t fSignalReferenceCut
the data set information (sometimes needed)
void SetWeightFileDir(TString fileDir)
set directory of weight file
XMLNodePointer_t DocGetRootElement(XMLDocPointer_t xmldoc)
returns root node of document
Double_t GetSignalReferenceCut() const
virtual void Sumw2(Bool_t flag=kTRUE)
Create structure to store sum of squares of weights.
A Graph is a graphics object made of two arrays X and Y with npoints each.
TH1 * GetOriginalHist() const
virtual TDirectory * GetDirectory(const char *namecycle, Bool_t printError=false, const char *funcname="GetDirectory")
Find a directory using apath.
you should not use this method at all Int_t Int_t Double_t Double_t Double_t Int_t Double_t Double_t Double_t Double_t b
THist< 1, double, THistStatContent, THistStatUncertainty > TH1D
Long64_t GetNEvents(Types::ETreeType type=Types::kMaxTreeType) const
virtual Double_t GetTrainingEfficiency(const TString &)
void AddOptionsXMLTo(void *parent) const
write options to XML file
Double_t GetIntegral(Double_t xmin, Double_t xmax)
computes PDF integral within given ranges
void ReadSpectatorsFromXML(void *specnode)
read spectator info from XML
Int_t Atoi() const
Return integer value of string.
Bool_t IsSignal(const Event *ev) const
void DrawProgressBar(Int_t, const TString &comment="")
draws progress bar in color or B&W caution:
std::vector< Bool_t > * GetValueVectorTypes()
ECutOrientation GetCutOrientation() const
void InitBase()
default initialization called by all constructors
std::vector< Float_t > * fRegressionReturnVal
Types::EAnalysisType GetAnalysisType() const
void AddTargetsXMLTo(void *parent) const
write target info to XML
void Store(TObject *obj, const char *alias=0)
virtual Int_t GetNbinsX() const
virtual void Add(TGraph *graph, Option_t *chopt="")
Add a new graph to the list of graphs.
Double_t Sqrt(Double_t x)
Class for type info of MVA input variable.
const TString & GetTestvarName() const
virtual Int_t GetSize() const
virtual void ReadWeightsFromStream(std::istream &)=0
virtual TMatrixD GetMulticlassConfusionMatrix(Double_t effB, Types::ETreeType type)
Construct a confusion matrix for a multiclass classifier.
Int_t Fill(Double_t)
Invalid Fill method.
THist< 2, float, THistStatContent, THistStatUncertainty > TH2F
void SetTestvarName(const TString &v="")
Types::EMVA GetMethodType() const
void CheckForUnusedOptions() const
checks for unused options in option string
virtual Int_t GetMaximumBin() const
Return location of bin with maximum value in the range.
Timing information for training and evaluation of MVA methods.
virtual void TestClassification()
initialization
void ReadStateFromStream(std::istream &tf)
read the header from the weight files of the different MVA methods
virtual Int_t Write(const char *name=0, Int_t option=0, Int_t bufsize=0)
Write all objects in this collection.
const Event * GetEvent() const
std::vector< VariableInfo > & GetVariableInfos()
void SetExternalLink(void *p)
virtual void SetAnalysisType(Types::EAnalysisType type)
void Resize(Int_t entries)
Class that is the base-class for a vector of result.
TAxis * GetXaxis()
Get the behaviour adopted by the object about the statoverflows. See EStatOverflows for more informat...
void NoErrorCalc(Double_t *const err, Double_t *const errUpper)
void SetSignalReferenceCut(Double_t cut)
void WriteOptionsToStream(std::ostream &o, const TString &prefix) const
write options to output stream (e.g. in writing the MVA weight files
void Resize(Ssiz_t n)
Resize the string. Truncate or add blanks as necessary.
This class stores the date and time with a precision of one second in an unsigned 32 bit word (950130...
Double_t GetVal(Double_t x) const
returns value PDF(x)
void SetConfigDescription(const char *d)
virtual void Close(Option_t *option="")
Close a file.
const char * Data() const