1 #ifndef CommonTools_Utils_TMVAEvaluator_h
2 #define CommonTools_Utils_TMVAEvaluator_h
10 #include "TMVA/Reader.h"
11 #include "TMVA/IMethod.h"
23 const std::vector<std::string> &
variables,
const std::vector<std::string> & spectators,
bool useGBRForest=
false,
bool useAdaBoost=
false);
25 const std::vector<std::string> & spectators,
bool useAdaBoost=
false);
27 const std::vector<std::string> & variables,
const std::vector<std::string> & spectators,
bool useAdaBoost=
false);
28 float evaluateTMVA(
const std::map<std::string,float> &
inputs,
bool useSpectators)
const;
30 float evaluate(
const std::map<std::string,float> & inputs,
bool useSpectators=
false)
const;
40 [[cms::thread_guard(
"m_mutex")]] std::unique_ptr<TMVA::Reader>
mReader;
44 [[cms::thread_guard(
"m_mutex")]]
mutable std::map<std::string,std::pair<size_t,float>>
mVariables;
45 [[cms::thread_guard(
"m_mutex")]]
mutable std::map<std::string,std::pair<size_t,float>>
mSpectators;
48 #endif // CommonTools_Utils_TMVAEvaluator_h
std::map< std::string, std::pair< size_t, float > > mVariables
static boost::mutex mutex
void initializeGBRForest(const GBRForest *gbrForest, const std::vector< std::string > &variables, const std::vector< std::string > &spectators, bool useAdaBoost=false)
void initialize(const std::string &options, const std::string &method, const std::string &weightFile, const std::vector< std::string > &variables, const std::vector< std::string > &spectators, bool useGBRForest=false, bool useAdaBoost=false)
std::map< std::string, std::pair< size_t, float > > mSpectators
float evaluateTMVA(const std::map< std::string, float > &inputs, bool useSpectators) const
std::unique_ptr< TMVA::Reader > mReader
std::unique_ptr< const GBRForest > mGBRForest
float evaluate(const std::map< std::string, float > &inputs, bool useSpectators=false) const
float evaluateGBRForest(const std::map< std::string, float > &inputs) const
std::unique_ptr< TMVA::IMethod > mIMethod