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