68 #ifndef IClassifierReader__def 69 #define IClassifierReader__def 71 class IClassifierReader {
76 IClassifierReader() : fStatusIsClean(
true ) {}
77 virtual ~IClassifierReader() {}
80 virtual double GetMvaValue(
const std::vector<double>& inputValues )
const = 0;
83 bool IsStatusClean()
const {
return fStatusIsClean; }
92 class ReadPDEFoam :
public IClassifierReader {
97 ReadPDEFoam( std::vector<std::string>& theInputVars )
98 : IClassifierReader(),
99 fClassName(
"ReadPDEFoam" ),
101 fIsNormalised(
false )
104 const char* inputVars[] = {
"var1+var2",
"var1-var2",
"var3",
"var4" };
107 if (theInputVars.size() <= 0) {
108 std::cout <<
"Problem in class \"" << fClassName <<
"\": empty input vector" << std::endl;
109 fStatusIsClean =
false;
112 if (theInputVars.size() != fNvars) {
113 std::cout <<
"Problem in class \"" << fClassName <<
"\": mismatch in number of input values: " 114 << theInputVars.size() <<
" != " << fNvars << std::endl;
115 fStatusIsClean =
false;
119 for (
size_t ivar = 0; ivar < theInputVars.size(); ivar++) {
120 if (theInputVars[ivar] != inputVars[ivar]) {
121 std::cout <<
"Problem in class \"" << fClassName <<
"\": mismatch in input variable names" << std::endl
122 <<
" for variable [" << ivar <<
"]: " << theInputVars[ivar].c_str() <<
" != " << inputVars[ivar] << std::endl;
123 fStatusIsClean =
false;
149 virtual ~ReadPDEFoam() {
156 double GetMvaValue(
const std::vector<double>& inputValues )
const;
164 const char* fClassName;
167 size_t GetNvar()
const {
return fNvars; }
171 const bool fIsNormalised;
172 bool IsNormalised()
const {
return fIsNormalised; }
175 double NormVariable(
double x,
double xmin,
double xmax )
const {
177 return 2*(x -
xmin)/(xmax - xmin) - 1.0;
185 double GetMvaValue__(
const std::vector<double>& inputValues )
const;
188 inline double ReadPDEFoam::GetMvaValue(
const std::vector<double>& inputValues )
const 194 if (!IsStatusClean()) {
195 std::cout <<
"Problem in class \"" << fClassName <<
"\": cannot return classifier response" 196 <<
" because status is dirty" << std::endl;
200 if (IsNormalised()) {
202 std::vector<double> iV;
203 iV.reserve(inputValues.size());
205 for (std::vector<double>::const_iterator varIt = inputValues.begin();
206 varIt != inputValues.end(); varIt++, ivar++) {
207 iV.push_back(NormVariable( *varIt, fVmin[ivar], fVmax[ivar] ));
209 retval = GetMvaValue__( iV );
212 retval = GetMvaValue__( inputValues );
Type GetType(const std::string &Name)
void Initialize(Bool_t useTMVAStyle=kTRUE)