CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
List of all members | Public Member Functions | Private Member Functions | Private Attributes
reco::FormulaEvaluator Class Reference

#include <FormulaEvaluator.h>

Public Member Functions

std::vector< std::string > abstractSyntaxTree () const
 
template<typename V , typename P >
double evaluate (V const &iVariables, P const &iParameters) const
 
 FormulaEvaluator (std::string const &iFormula)
 
unsigned int numberOfParameters () const
 
unsigned int numberOfVariables () const
 

Private Member Functions

double evaluate (double const *iVariables, double const *iParameters) const
 
void throwWrongNumberOfParameters (size_t) const
 
void throwWrongNumberOfVariables (size_t) const
 

Private Attributes

std::shared_ptr
< formula::EvaluatorBase const > 
m_evaluator
 
unsigned int m_nParameters = 0
 
unsigned int m_nVariables = 0
 

Detailed Description

Definition at line 67 of file FormulaEvaluator.h.

Constructor & Destructor Documentation

FormulaEvaluator::FormulaEvaluator ( std::string const &  iFormula)
explicit

Definition at line 902 of file FormulaEvaluator.cc.

References cms::cuda::assert(), DEBUG_STATE, Exception, EcalElecEmulTccOnlyExample_cfg::formula, lastIndex, m_evaluator, m_nParameters, m_nVariables, eostools::move(), or, and AlCaHLTBitMon_QueryRunRegistry::string.

902  {
903  //remove white space
905  formula.reserve(iFormula.size());
906  std::copy_if(iFormula.begin(), iFormula.end(), std::back_inserter(formula), [](const char iC) { return iC != ' '; });
907 
908  auto info = s_expressionFinder.createEvaluator(
909  formula.begin(), formula.end(), std::shared_ptr<reco::formula::BinaryOperatorEvaluatorBase>());
910 
911  if (info.nextParseIndex != static_cast<int>(formula.size()) or info.top.get() == nullptr) {
912  auto lastIndex = info.nextParseIndex;
913  if (formula.size() != iFormula.size()) {
914  lastIndex = 0;
915  for (decltype(info.nextParseIndex) index = 0; index < info.nextParseIndex; ++index, ++lastIndex) {
916  while (iFormula[lastIndex] != formula[index]) {
917  assert(iFormula[lastIndex] == ' ');
918  ++lastIndex;
919  }
920  }
921  }
922  throw cms::Exception("FormulaEvaluatorParseError")
923  << "While parsing '" << iFormula << "' could not parse beyond '"
924  << std::string(iFormula.begin(), iFormula.begin() + lastIndex) << "'";
925  }
926 
927  DEBUG_STATE("DONE parsing");
928  printAST(info.top.get());
929 
930  m_evaluator = std::move(info.top);
931  m_nVariables = info.maxNumVariables;
932  m_nParameters = info.maxNumParameters;
933 }
static const TGPicture * info(bool iBackgroundIsBlack)
The Signals That Services Can Subscribe To This is based on ActivityRegistry and is current per Services can connect to the signals distributed by the ActivityRegistry in order to monitor the activity of the application Each possible callback has some defined which we here list in angle e< void, edm::EventIDconst &, edm::Timestampconst & > We also list in braces which AR_WATCH_USING_METHOD_ is used for those or
Definition: Activities.doc:12
assert(be >=bs)
#define DEBUG_STATE(_v_)
def move
Definition: eostools.py:511
static std::atomic< unsigned int > lastIndex
Definition: DDValue.cc:12
std::shared_ptr< formula::EvaluatorBase const > m_evaluator

Member Function Documentation

std::vector< std::string > FormulaEvaluator::abstractSyntaxTree ( ) const

Definition at line 951 of file FormulaEvaluator.cc.

References m_evaluator.

951 { return m_evaluator->abstractSyntaxTree(); }
std::shared_ptr< formula::EvaluatorBase const > m_evaluator
template<typename V , typename P >
double reco::FormulaEvaluator::evaluate ( V const &  iVariables,
P const &  iParameters 
) const
inline

Definition at line 73 of file FormulaEvaluator.h.

References m_nParameters, m_nVariables, reco::formula::startingAddress(), throwWrongNumberOfParameters(), and throwWrongNumberOfVariables().

Referenced by L1HPSPFTauBuilder::addL1PFCandidates(), SimpleJetCorrector::correctionBin(), SimpleJetCorrector::invert(), main(), ETLUncalibRecHitAlgo::makeRecHit(), BTLUncalibRecHitAlgo::makeRecHit(), ETLElectronicsSim::run(), and TotemTimingConversions::voltSamples().

73  {
74  if (m_nVariables > iVariables.size()) {
75  throwWrongNumberOfVariables(iVariables.size());
76  }
77  if (m_nParameters > iParameters.size()) {
78  throwWrongNumberOfParameters(iParameters.size());
79  }
80  return evaluate(formula::startingAddress(iVariables), formula::startingAddress(iParameters));
81  }
double evaluate(V const &iVariables, P const &iParameters) const
void throwWrongNumberOfParameters(size_t) const
double const * startingAddress(ArrayAdaptor const &iV)
void throwWrongNumberOfVariables(size_t) const
double FormulaEvaluator::evaluate ( double const *  iVariables,
double const *  iParameters 
) const
private

Definition at line 938 of file FormulaEvaluator.cc.

References m_evaluator.

938  {
939  return m_evaluator->evaluate(iVariables, iParameters);
940 }
std::shared_ptr< formula::EvaluatorBase const > m_evaluator
unsigned int reco::FormulaEvaluator::numberOfParameters ( ) const
inline
unsigned int reco::FormulaEvaluator::numberOfVariables ( ) const
inline

Definition at line 84 of file FormulaEvaluator.h.

References m_nVariables.

Referenced by TotemTimingConversions::voltSamples().

84 { return m_nVariables; }
void FormulaEvaluator::throwWrongNumberOfParameters ( size_t  iSize) const
private

Definition at line 946 of file FormulaEvaluator.cc.

References Exception, and m_nParameters.

Referenced by evaluate().

946  {
947  throw cms::Exception("WrongNumParameters")
948  << "FormulaEvaluator expected at least " << m_nParameters << " but was passed only " << iSize;
949 }
void FormulaEvaluator::throwWrongNumberOfVariables ( size_t  iSize) const
private

Definition at line 942 of file FormulaEvaluator.cc.

References Exception, and m_nVariables.

Referenced by evaluate().

942  {
943  throw cms::Exception("WrongNumVariables")
944  << "FormulaEvaluator expected at least " << m_nVariables << " but was passed only " << iSize;
945 }

Member Data Documentation

std::shared_ptr<formula::EvaluatorBase const> reco::FormulaEvaluator::m_evaluator
private

Definition at line 94 of file FormulaEvaluator.h.

Referenced by abstractSyntaxTree(), evaluate(), and FormulaEvaluator().

unsigned int reco::FormulaEvaluator::m_nParameters = 0
private
unsigned int reco::FormulaEvaluator::m_nVariables = 0
private