CMS 3D CMS Logo

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 DEBUG_STATE, Exception, pfMETCorrectionType0_cfi::formula, info(), lastIndex, 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)
#define DEBUG_STATE(_v_)
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::EventID const &, edm::Timestamp const & > We also list in braces which AR_WATCH_USING_METHOD_ is used for those or
Definition: Activities.doc:12
static std::atomic< unsigned int > lastIndex
Definition: DDValue.cc:12
std::shared_ptr< formula::EvaluatorBase const > m_evaluator
def move(src, dest)
Definition: eostools.py:511

Member Function Documentation

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

Definition at line 951 of file FormulaEvaluator.cc.

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 reco::formula::startingAddress().

Referenced by SimpleJetCorrector::correctionBin(), SimpleJetCorrector::invert(), main(), CTPPSTimingTrackRecognition< TRACK_TYPE, HIT_TYPE >::producePartialTracks(), 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.

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.

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.

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.

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.

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

Definition at line 96 of file FormulaEvaluator.h.

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

Definition at line 95 of file FormulaEvaluator.h.