1 #include "KVEventClassifier.h"
24 value_to_test = value_to_test + gRandom->Uniform();
26 std::vector<double>::const_iterator result = std::find_if(
fCuts.begin(),
fCuts.end(),
27 [value_to_test](
double x) {
28 return x > value_to_test;
31 return std::distance(
fCuts.begin(), result);
54 if (
fVal.Contains(p.GetName())) {
55 fValues.push_back(std::string(p.GetName()));
56 fVal.ReplaceAll(p.GetName(), Form(
"[%d]", nval));
65 Error(
"Init()",
"Tried to make event classifier for variable %s using expression: %s",
fVar->GetName(),
fVal.Data());
Simple class for sorting events according to global variables.
std::unique_ptr< TFormula > fFormula
in case a combination of values is used
bool fWithExpression
true if an expression using several values is used
std::vector< double > fCuts
cuts in variable to define event classes
std::vector< std::string > fValues
indices of values in parsed expression
bool fWithVal
true if named value given
bool fIntegerVariable
true if global variable used for cuts has integer values
KVVarGlob * fVar
variable used for event classification
TString fVal
optional name of value calculated by variable to use
const KVNameValueList & GetValueNameList() const
Double_t GetValue(void) const
Bool_t HasValue(const Char_t *name) const
Int_t GetNameIndex(const Char_t *name) const
virtual Char_t GetValueType(Int_t) const