CMS 3D CMS Logo

List of all members | Public Member Functions | Private Member Functions | Private Attributes | Friends
JME::JetResolutionObject::Definition Class Reference

#include <JetResolutionObject.h>

Public Member Functions

 Definition ()
 
 Definition (const std::string &definition)
 
std::string getBinName (size_t bin) const
 
const std::vector< Binning > & getBins () const
 
const std::vector< std::string > & getBinsName () const
 
const reco::FormulaEvaluatorgetFormula () const
 
std::string getFormulaString () const
 
std::string getVariableName (size_t variable) const
 
const std::vector< Binning > & getVariables () const
 
const std::vector< std::string > & getVariablesName () const
 
void init ()
 
size_t nBins () const
 
size_t nVariables () const
 

Private Member Functions

template<class Archive >
void serialize (Archive &ar, const unsigned int version)
 

Private Attributes

std::vector< Binningm_bins
 
std::vector< std::string > m_bins_name
 
std::shared_ptr< reco::FormulaEvaluatorm_formula
 
std::string m_formula_str
 
std::vector< Binningm_variables
 
std::vector< std::string > m_variables_name
 

Friends

class boost::serialization::access
 
template<typename CondSerializationT , typename Enabled >
struct cond::serialization::access
 

Detailed Description

Definition at line 136 of file JetResolutionObject.h.

Constructor & Destructor Documentation

JME::JetResolutionObject::Definition::Definition ( )
inline

Definition at line 138 of file JetResolutionObject.h.

References AlCaHLTBitMon_QueryRunRegistry::string.

138  {
139  // Empty
140  }
JME::JetResolutionObject::Definition::Definition ( const std::string &  definition)

Definition at line 133 of file JetResolutionObject.cc.

References edm::errors::ConfigFileReadError, mps_fire::i, init, AlCaHLTBitMon_QueryRunRegistry::string, JME::throwException(), and HcalDetIdTransform::transform().

133  {
134  std::vector<std::string> tokens = getTokens(definition);
135 
136  // We need at least 3 tokens
137  if (tokens.size() < 3) {
139  "Definition line needs at least three tokens. Please check file format.");
140  }
141 
142  size_t n_bins = std::stoul(tokens[0]);
143 
144  if (tokens.size() < (n_bins + 2)) {
145  throwException(edm::errors::ConfigFileReadError, "Invalid file format. Please check.");
146  }
147 
148  for (size_t i = 0; i < n_bins; i++) {
149  m_bins_name.push_back(tokens[i + 1]);
150  }
151 
152  size_t n_variables = std::stoul(tokens[n_bins + 1]);
153 
154  if (tokens.size() < (1 + n_bins + 1 + n_variables + 1)) {
155  throwException(edm::errors::ConfigFileReadError, "Invalid file format. Please check.");
156  }
157 
158  for (size_t i = 0; i < n_variables; i++) {
159  m_variables_name.push_back(tokens[n_bins + 2 + i]);
160  }
161 
162  m_formula_str = tokens[n_bins + n_variables + 2];
163 
164  std::string formula_str_lower = m_formula_str;
165  std::transform(formula_str_lower.begin(), formula_str_lower.end(), formula_str_lower.begin(), ::tolower);
166 
167  if (formula_str_lower == "none")
168  m_formula_str = "";
169 
170  init();
171  }
std::vector< std::string > m_variables_name
std::vector< std::string > m_bins_name
void throwException(uint32_t code, const std::string &message)
unsigned transform(const HcalDetId &id, unsigned transformCode)

Member Function Documentation

std::string JME::JetResolutionObject::Definition::getBinName ( size_t  bin) const
inline

Definition at line 148 of file JetResolutionObject.h.

References newFWLiteAna::bin.

148 { return m_bins_name[bin]; }
std::vector< std::string > m_bins_name
const std::vector<Binning>& JME::JetResolutionObject::Definition::getBins ( ) const
inline

Definition at line 146 of file JetResolutionObject.h.

Referenced by JetResolutionDemo::analyze().

146 { return m_bins; }
const std::vector<std::string>& JME::JetResolutionObject::Definition::getBinsName ( ) const
inline

Definition at line 144 of file JetResolutionObject.h.

144 { return m_bins_name; }
std::vector< std::string > m_bins_name
const reco::FormulaEvaluator* JME::JetResolutionObject::Definition::getFormula ( ) const
inline

Definition at line 163 of file JetResolutionObject.h.

References init.

163 { return m_formula.get(); }
std::shared_ptr< reco::FormulaEvaluator > m_formula
std::string JME::JetResolutionObject::Definition::getFormulaString ( ) const
inline

Definition at line 160 of file JetResolutionObject.h.

std::string JME::JetResolutionObject::Definition::getVariableName ( size_t  variable) const
inline
const std::vector<Binning>& JME::JetResolutionObject::Definition::getVariables ( ) const
inline

Definition at line 154 of file JetResolutionObject.h.

154 { return m_variables; }
const std::vector<std::string>& JME::JetResolutionObject::Definition::getVariablesName ( ) const
inline

Definition at line 152 of file JetResolutionObject.h.

152 { return m_variables_name; }
std::vector< std::string > m_variables_name
void JME::JetResolutionObject::Definition::init ( void  )

Definition at line 173 of file JetResolutionObject.cc.

References b, newFWLiteAna::bin, JME::throwException(), edm::errors::UnimplementedFeature, findQualityFiles::v, and trigObjTnPSource_cfi::var.

173  {
174  if (!m_formula_str.empty())
175 #ifndef STANDALONE
176  m_formula = std::make_shared<reco::FormulaEvaluator>(m_formula_str);
177 #else
178  m_formula = std::make_shared<TFormula>("jet_resolution_formula", m_formula_str.c_str());
179 #endif
180  for (const auto& bin : m_bins_name) {
181  const auto& b = JetParameters::binning_to_string.right.find(bin);
182  if (b == JetParameters::binning_to_string.right.cend()) {
183  throwException(edm::errors::UnimplementedFeature, "Bin name not supported: '" + bin + "'");
184  }
185  m_bins.push_back(b->second);
186  }
187 
188  for (const auto& v : m_variables_name) {
189  const auto& var = JetParameters::binning_to_string.right.find(v);
190  if (var == JetParameters::binning_to_string.right.cend()) {
191  throwException(edm::errors::UnimplementedFeature, "Variable name not supported: '" + v + "'");
192  }
193  m_variables.push_back(var->second);
194  }
195  }
std::shared_ptr< reco::FormulaEvaluator > m_formula
std::vector< std::string > m_variables_name
std::vector< std::string > m_bins_name
right_type right
double b
Definition: hdecay.h:118
void throwException(uint32_t code, const std::string &message)
static const bimap< Binning, std::string > binning_to_string
size_t JME::JetResolutionObject::Definition::nBins ( ) const
inline

Definition at line 150 of file JetResolutionObject.h.

Referenced by JME::JetResolutionObject::Record::Record().

150 { return m_bins_name.size(); }
std::vector< std::string > m_bins_name
size_t JME::JetResolutionObject::Definition::nVariables ( ) const
inline

Definition at line 158 of file JetResolutionObject.h.

Referenced by JME::JetResolutionObject::Record::Record().

158 { return m_variables.size(); }
template<class Archive >
void JME::JetResolutionObject::Definition::serialize ( Archive &  ar,
const unsigned int  version 
)
private

Friends And Related Function Documentation

friend class boost::serialization::access
friend

Definition at line 182 of file JetResolutionObject.h.

template<typename CondSerializationT , typename Enabled >
friend struct cond::serialization::access
friend

Definition at line 182 of file JetResolutionObject.h.

Member Data Documentation

std::vector<Binning> JME::JetResolutionObject::Definition::m_bins
private

Definition at line 179 of file JetResolutionObject.h.

std::vector<std::string> JME::JetResolutionObject::Definition::m_bins_name
private

Definition at line 170 of file JetResolutionObject.h.

std::shared_ptr<reco::FormulaEvaluator> JME::JetResolutionObject::Definition::m_formula
private

Definition at line 175 of file JetResolutionObject.h.

std::string JME::JetResolutionObject::Definition::m_formula_str
private

Definition at line 172 of file JetResolutionObject.h.

std::vector<Binning> JME::JetResolutionObject::Definition::m_variables
private

Definition at line 180 of file JetResolutionObject.h.

std::vector<std::string> JME::JetResolutionObject::Definition::m_variables_name
private

Definition at line 171 of file JetResolutionObject.h.