CMS 3D CMS Logo

List of all members | Classes | Public Member Functions | Protected Attributes | Private Member Functions | Friends
EcalMustacheSCParameters Class Reference

#include <EcalMustacheSCParameters.h>

Classes

struct  ParabolaParameters
 

Public Member Functions

 EcalMustacheSCParameters ()
 
const ParabolaParametersparabolaParameters (float log10ClustE, float absSeedEta) const
 
void print (std::ostream &) const
 
float sqrtLogClustETuning () const
 
virtual ~EcalMustacheSCParameters ()=default
 

Protected Attributes

std::vector< ParabolaParametersparabolaParametersCollection_
 
float sqrtLogClustETuning_
 

Private Member Functions

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

Friends

class boost::serialization::access
 
template<typename CondSerializationT , typename Enabled >
struct cond::serialization::access
 
std::ostream & operator<< (std::ostream &out, const EcalMustacheSCParameters &params)
 
class reco::MustacheSCParametersHelper
 

Detailed Description

Definition at line 13 of file EcalMustacheSCParameters.h.

Constructor & Destructor Documentation

◆ EcalMustacheSCParameters()

EcalMustacheSCParameters::EcalMustacheSCParameters ( )
inline

Definition at line 15 of file EcalMustacheSCParameters.h.

15 {};

◆ ~EcalMustacheSCParameters()

virtual EcalMustacheSCParameters::~EcalMustacheSCParameters ( )
virtualdefault

Member Function Documentation

◆ parabolaParameters()

const EcalMustacheSCParameters::ParabolaParameters * EcalMustacheSCParameters::parabolaParameters ( float  log10ClustE,
float  absSeedEta 
) const

Definition at line 6 of file EcalMustacheSCParameters.cc.

References pfDeepBoostedJetPreprocessParams_cfi::lower_bound, parabolaParametersCollection_, submitPVValidationJobs::params, and trigObjTnPSource_cfi::var.

7  {
8  // assume the collection is lexicographically sorted in ascending ParabolaParameters.log10EMin and ascending ParabolaParameters.etaMin
9  // find the matching log10EMin value
12  log10ClustE,
14  return params.log10EMin < var;
15  });
16  if (it1 != parabolaParametersCollection_.begin()) {
17  --it1;
18  }
19 
20  // find the matching log10EMin and etaMin entry going only up to the sets matching for log10ClustE
21  const auto vars = std::make_pair(it1->log10EMin, absSeedEta);
22  auto it2 = std::lower_bound(
24  it1 + 1,
25  vars,
26  [](const EcalMustacheSCParameters::ParabolaParameters& params, const std::pair<double, double> vars) {
27  return params.log10EMin < vars.first || params.etaMin < vars.second;
28  });
29 
30  return (it2 != parabolaParametersCollection_.begin()) ? &*(it2 - 1) : nullptr;
31 }
std::vector< ParabolaParameters > parabolaParametersCollection_
vars
Definition: DeepTauId.cc:30

◆ print()

void EcalMustacheSCParameters::print ( std::ostream &  out) const

Definition at line 33 of file EcalMustacheSCParameters.cc.

References mps_fire::i, MillePedeFileConverter_cfg::out, parabolaParametersCollection_, submitPVValidationJobs::params, and sqrtLogClustETuning_.

33  {
34  out << "Mustache SC parameters:" << std::endl;
35  out << " sqrtLogClustETuning: " << sqrtLogClustETuning_ << std::endl;
36  out << " Parabola parameters are binned in " << parabolaParametersCollection_.size() << " (log10(E), |eta|) regions."
37  << std::endl;
38  for (const auto& params : parabolaParametersCollection_) {
39  out << " Parameters for log10(E_min)=" << params.log10EMin << " and |eta_min|=" << params.etaMin << ":"
40  << std::endl;
41 
42  out << " pUp:" << std::endl;
43  for (size_t i = 0; i < params.pUp.size(); ++i) {
44  out << " [" << i << "]: " << params.pUp[i] << std::endl;
45  }
46 
47  out << " pLow:" << std::endl;
48  for (size_t i = 0; i < params.pLow.size(); ++i) {
49  out << " [" << i << "]: " << params.pLow[i] << std::endl;
50  }
51 
52  out << " w0Up:" << std::endl;
53  for (size_t i = 0; i < params.w0Up.size(); ++i) {
54  out << " [" << i << "]: " << params.w0Up[i] << std::endl;
55  }
56 
57  out << " w1Up:" << std::endl;
58  for (size_t i = 0; i < params.w1Up.size(); ++i) {
59  out << " [" << i << "]: " << params.w1Up[i] << std::endl;
60  }
61 
62  out << " w0Low:" << std::endl;
63  for (size_t i = 0; i < params.w0Low.size(); ++i) {
64  out << " [" << i << "]: " << params.w0Low[i] << std::endl;
65  }
66 
67  out << " w1Low:" << std::endl;
68  for (size_t i = 0; i < params.w1Low.size(); ++i) {
69  out << " [" << i << "]: " << params.w1Low[i] << std::endl;
70  }
71  }
72 }
std::vector< ParabolaParameters > parabolaParametersCollection_

◆ serialize()

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

◆ sqrtLogClustETuning()

float EcalMustacheSCParameters::sqrtLogClustETuning ( ) const

Definition at line 4 of file EcalMustacheSCParameters.cc.

References sqrtLogClustETuning_.

Friends And Related Function Documentation

◆ boost::serialization::access

friend class boost::serialization::access
friend

Definition at line 51 of file EcalMustacheSCParameters.h.

◆ cond::serialization::access

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

Definition at line 51 of file EcalMustacheSCParameters.h.

◆ operator<<

std::ostream& operator<< ( std::ostream &  out,
const EcalMustacheSCParameters params 
)
friend

Definition at line 40 of file EcalMustacheSCParameters.h.

◆ reco::MustacheSCParametersHelper

friend class reco::MustacheSCParametersHelper
friend

Definition at line 36 of file EcalMustacheSCParameters.h.

Member Data Documentation

◆ parabolaParametersCollection_

std::vector<ParabolaParameters> EcalMustacheSCParameters::parabolaParametersCollection_
protected

◆ sqrtLogClustETuning_

float EcalMustacheSCParameters::sqrtLogClustETuning_
protected