CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
List of all members | Public Member Functions | Protected Attributes
EcalUncalibRecHitWorkerRatio Class Reference

#include <EcalUncalibRecHitWorkerRatio.h>

Inheritance diagram for EcalUncalibRecHitWorkerRatio:
EcalUncalibRecHitWorkerBaseClass

Public Member Functions

 EcalUncalibRecHitWorkerRatio (const edm::ParameterSet &)
 
bool run (const edm::Event &evt, const EcalDigiCollection::const_iterator &digi, EcalUncalibratedRecHitCollection &result)
 
void set (const edm::EventSetup &es)
 
virtual ~EcalUncalibRecHitWorkerRatio ()
 
- Public Member Functions inherited from EcalUncalibRecHitWorkerBaseClass
 EcalUncalibRecHitWorkerBaseClass (const edm::ParameterSet &)
 
virtual ~EcalUncalibRecHitWorkerBaseClass ()
 

Protected Attributes

std::vector< double > EBamplitudeFitParameters_
 
double EBtimeConstantTerm_
 
std::pair< double, double > EBtimeFitLimits_
 
std::vector< double > EBtimeFitParameters_
 
std::vector< double > EEamplitudeFitParameters_
 
double EEtimeConstantTerm_
 
std::pair< double, double > EEtimeFitLimits_
 
std::vector< double > EEtimeFitParameters_
 
double gainRatios [3]
 
edm::ESHandle< EcalGainRatiosgains
 
double pedRMSVec [3]
 
edm::ESHandle< EcalPedestalspeds
 
double pedVec [3]
 
EcalUncalibRecHitRatioMethodAlgo
< EBDataFrame
uncalibMaker_barrel_
 
EcalUncalibRecHitRatioMethodAlgo
< EEDataFrame
uncalibMaker_endcap_
 

Detailed Description

Definition at line 26 of file EcalUncalibRecHitWorkerRatio.h.

Constructor & Destructor Documentation

EcalUncalibRecHitWorkerRatio::EcalUncalibRecHitWorkerRatio ( const edm::ParameterSet ps)

Definition at line 11 of file EcalUncalibRecHitWorkerRatio.cc.

References EBamplitudeFitParameters_, EBtimeConstantTerm_, EBtimeFitLimits_, EBtimeFitParameters_, EEamplitudeFitParameters_, EEtimeConstantTerm_, EEtimeFitLimits_, EEtimeFitParameters_, and edm::ParameterSet::getParameter().

11  :
13 {
14  EBtimeFitParameters_ = ps.getParameter<std::vector<double> >("EBtimeFitParameters");
15  EEtimeFitParameters_ = ps.getParameter<std::vector<double> >("EEtimeFitParameters");
16 
17  EBamplitudeFitParameters_ = ps.getParameter<std::vector<double> >("EBamplitudeFitParameters");
18  EEamplitudeFitParameters_ = ps.getParameter<std::vector<double> >("EEamplitudeFitParameters");
19 
20  EBtimeFitLimits_.first = ps.getParameter<double>("EBtimeFitLimits_Lower");
21  EBtimeFitLimits_.second = ps.getParameter<double>("EBtimeFitLimits_Upper");
22 
23  EEtimeFitLimits_.first = ps.getParameter<double>("EEtimeFitLimits_Lower");
24  EEtimeFitLimits_.second = ps.getParameter<double>("EEtimeFitLimits_Upper");
25 
26  EBtimeConstantTerm_ = ps.getParameter<double>("EBtimeConstantTerm");
27  EEtimeConstantTerm_ = ps.getParameter<double>("EEtimeConstantTerm");
28 }
T getParameter(std::string const &) const
std::vector< double > EEamplitudeFitParameters_
std::pair< double, double > EEtimeFitLimits_
EcalUncalibRecHitWorkerBaseClass(const edm::ParameterSet &)
std::pair< double, double > EBtimeFitLimits_
std::vector< double > EBamplitudeFitParameters_
virtual EcalUncalibRecHitWorkerRatio::~EcalUncalibRecHitWorkerRatio ( )
inlinevirtual

Definition at line 30 of file EcalUncalibRecHitWorkerRatio.h.

30 {};

Member Function Documentation

bool EcalUncalibRecHitWorkerRatio::run ( const edm::Event evt,
const EcalDigiCollection::const_iterator digi,
EcalUncalibratedRecHitCollection result 
)
virtual

Implements EcalUncalibRecHitWorkerBaseClass.

Definition at line 40 of file EcalUncalibRecHitWorkerRatio.cc.

References EcalUncalibRecHitRatioMethodAlgo< C >::computeAmplitude(), EcalUncalibRecHitRatioMethodAlgo< C >::computeTime(), cond::rpcobgas::detid, EBamplitudeFitParameters_, EBtimeConstantTerm_, EBtimeFitLimits_, EBtimeFitParameters_, EcalEndcap, EEamplitudeFitParameters_, EEtimeConstantTerm_, EEtimeFitLimits_, EEtimeFitParameters_, EcalUncalibRecHitRatioMethodAlgo< C >::fixMGPAslew(), EcalMGPAGainRatio::gain12Over6(), EcalMGPAGainRatio::gain6Over1(), gainRatios, gains, EcalUncalibRecHitRatioMethodAlgo< C >::getCalculatedRecHit(), ecalpyutils::hashedIndex(), EBDetId::hashedIndex(), EEDetId::hashedIndex(), EcalUncalibRecHitRatioMethodAlgo< C >::init(), pedRMSVec, peds, pedVec, funct::pow(), edm::SortedCollection< T, SORT >::push_back(), EcalUncalibratedRecHit::setAmplitude(), EcalUncalibratedRecHit::setJitter(), EcalUncalibratedRecHit::setJitterError(), mathSSE::sqrt(), uncalibMaker_barrel_, and uncalibMaker_endcap_.

43 {
44  DetId detid(itdg->id());
45 
46  const EcalPedestals::Item * aped = 0;
47  const EcalMGPAGainRatio * aGain = 0;
48 
49  if (detid.subdetId()==EcalEndcap) {
50  unsigned int hashedIndex = EEDetId(detid).hashedIndex();
51  aped = &peds->endcap(hashedIndex);
52  aGain = &gains->endcap(hashedIndex);
53  } else {
54  unsigned int hashedIndex = EBDetId(detid).hashedIndex();
55  aped = &peds->barrel(hashedIndex);
56  aGain = &gains->barrel(hashedIndex);
57  }
58 
59  pedVec[0] = aped->mean_x12;
60  pedVec[1] = aped->mean_x6;
61  pedVec[2] = aped->mean_x1;
62  pedRMSVec[0] = aped->rms_x12;
63  pedRMSVec[1] = aped->rms_x6;
64  pedRMSVec[2] = aped->rms_x1;
65  gainRatios[0] = 1.;
66  gainRatios[1] = aGain->gain12Over6();
67  gainRatios[2] = aGain->gain6Over1()*aGain->gain12Over6();
68 
69  float clockToNsConstant = 25.;
70  EcalUncalibratedRecHit uncalibRecHit;
71 
72  if (detid.subdetId()==EcalEndcap) {
80  uncalibRecHit.setAmplitude( crh.amplitudeMax );
81  uncalibRecHit.setJitter( crh.timeMax - 5 );
82  uncalibRecHit.setJitterError( std::sqrt(pow(crh.timeError,2) +
84  std::pow(clockToNsConstant,2)) );
85 
86  } else {
87 
89  bool gainSwitch = uncalibMaker_barrel_.fixMGPAslew(*itdg);
96  uncalibRecHit.setAmplitude( crh.amplitudeMax );
97  if(gainSwitch){
98  // introduce additional 1ns shift
99  uncalibRecHit.setJitter( crh.timeMax - 5 - 0.04 );
100  }else{
101  uncalibRecHit.setJitter( crh.timeMax - 5);
102  }
103  uncalibRecHit.setJitterError( std::sqrt(pow(crh.timeError,2) +
105  std::pow(clockToNsConstant,2)) );
106 
107  }
108  result.push_back(uncalibRecHit);
109 
110  return true;
111 }
int hashedIndex() const
get a compact index for arrays
Definition: EBDetId.h:73
void computeAmplitude(std::vector< double > &amplitudeFitParameters)
EcalUncalibRecHitRatioMethodAlgo< EBDataFrame > uncalibMaker_barrel_
edm::ESHandle< EcalPedestals > peds
void computeTime(std::vector< double > &timeFitParameters, std::pair< double, double > &timeFitLimits, std::vector< double > &amplitudeFitParameters)
std::vector< double > EEamplitudeFitParameters_
void push_back(T const &t)
std::pair< double, double > EEtimeFitLimits_
edm::ESHandle< EcalGainRatios > gains
void setJitterError(float jitterErr)
int hashedIndex(int ieta, int iphi)
Definition: EcalPyUtils.cc:42
T sqrt(T t)
Definition: SSEVec.h:28
float gain6Over1() const
void setJitter(double jitter)
Definition: DetId.h:20
int hashedIndex() const
Definition: EEDetId.h:177
void init(const C &dataFrame, const double *pedestals, const double *pedestalRMSes, const double *gainRatios)
float gain12Over6() const
std::pair< double, double > EBtimeFitLimits_
EcalUncalibRecHitRatioMethodAlgo< EEDataFrame > uncalibMaker_endcap_
std::vector< double > EBamplitudeFitParameters_
void setAmplitude(double amplitude)
Power< A, B >::type pow(const A &a, const B &b)
Definition: Power.h:40
void EcalUncalibRecHitWorkerRatio::set ( const edm::EventSetup es)
virtual

Implements EcalUncalibRecHitWorkerBaseClass.

Definition at line 31 of file EcalUncalibRecHitWorkerRatio.cc.

References gains, edm::EventSetup::get(), and peds.

32 {
33  es.get<EcalGainRatiosRcd>().get(gains);
34  es.get<EcalPedestalsRcd>().get(peds);
35 
36 }
edm::ESHandle< EcalPedestals > peds
edm::ESHandle< EcalGainRatios > gains
const T & get() const
Definition: EventSetup.h:55

Member Data Documentation

std::vector<double> EcalUncalibRecHitWorkerRatio::EBamplitudeFitParameters_
protected

Definition at line 47 of file EcalUncalibRecHitWorkerRatio.h.

Referenced by EcalUncalibRecHitWorkerRatio(), and run().

double EcalUncalibRecHitWorkerRatio::EBtimeConstantTerm_
protected

Definition at line 53 of file EcalUncalibRecHitWorkerRatio.h.

Referenced by EcalUncalibRecHitWorkerRatio(), and run().

std::pair<double,double> EcalUncalibRecHitWorkerRatio::EBtimeFitLimits_
protected

Definition at line 50 of file EcalUncalibRecHitWorkerRatio.h.

Referenced by EcalUncalibRecHitWorkerRatio(), and run().

std::vector<double> EcalUncalibRecHitWorkerRatio::EBtimeFitParameters_
protected

Definition at line 44 of file EcalUncalibRecHitWorkerRatio.h.

Referenced by EcalUncalibRecHitWorkerRatio(), and run().

std::vector<double> EcalUncalibRecHitWorkerRatio::EEamplitudeFitParameters_
protected

Definition at line 48 of file EcalUncalibRecHitWorkerRatio.h.

Referenced by EcalUncalibRecHitWorkerRatio(), and run().

double EcalUncalibRecHitWorkerRatio::EEtimeConstantTerm_
protected

Definition at line 54 of file EcalUncalibRecHitWorkerRatio.h.

Referenced by EcalUncalibRecHitWorkerRatio(), and run().

std::pair<double,double> EcalUncalibRecHitWorkerRatio::EEtimeFitLimits_
protected

Definition at line 51 of file EcalUncalibRecHitWorkerRatio.h.

Referenced by EcalUncalibRecHitWorkerRatio(), and run().

std::vector<double> EcalUncalibRecHitWorkerRatio::EEtimeFitParameters_
protected

Definition at line 45 of file EcalUncalibRecHitWorkerRatio.h.

Referenced by EcalUncalibRecHitWorkerRatio(), and run().

double EcalUncalibRecHitWorkerRatio::gainRatios[3]
protected

Definition at line 42 of file EcalUncalibRecHitWorkerRatio.h.

Referenced by run().

edm::ESHandle<EcalGainRatios> EcalUncalibRecHitWorkerRatio::gains
protected

Definition at line 38 of file EcalUncalibRecHitWorkerRatio.h.

Referenced by run(), and set().

double EcalUncalibRecHitWorkerRatio::pedRMSVec[3]
protected

Definition at line 41 of file EcalUncalibRecHitWorkerRatio.h.

Referenced by run().

edm::ESHandle<EcalPedestals> EcalUncalibRecHitWorkerRatio::peds
protected

Definition at line 37 of file EcalUncalibRecHitWorkerRatio.h.

Referenced by run(), and set().

double EcalUncalibRecHitWorkerRatio::pedVec[3]
protected

Definition at line 40 of file EcalUncalibRecHitWorkerRatio.h.

Referenced by run().

EcalUncalibRecHitRatioMethodAlgo<EBDataFrame> EcalUncalibRecHitWorkerRatio::uncalibMaker_barrel_
protected

Definition at line 56 of file EcalUncalibRecHitWorkerRatio.h.

Referenced by run().

EcalUncalibRecHitRatioMethodAlgo<EEDataFrame> EcalUncalibRecHitWorkerRatio::uncalibMaker_endcap_
protected

Definition at line 57 of file EcalUncalibRecHitWorkerRatio.h.

Referenced by run().