CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
HcalSignalGenerator.h
Go to the documentation of this file.
1 #ifndef HcalSimAlgos_HcalSignalGenerator_h
2 #define HcalSimAlgos_HcalSignalGenerator_h
3 
17 
22 #include <iostream>
23 
24 namespace edm {
25  class ModuleCallingContext;
26 }
27 
28 template<class HCALDIGITIZERTRAITS>
30 {
31 public:
32  typedef typename HCALDIGITIZERTRAITS::Digi DIGI;
33  typedef typename HCALDIGITIZERTRAITS::DigiCollection COLLECTION;
34 
36 
39  { }
40 
41  virtual ~HcalSignalGenerator() {}
42 
43 
44  void initializeEvent(const edm::Event * event, const edm::EventSetup * eventSetup)
45  {
46  theEvent = event;
47  eventSetup->get<HcalDbRecord>().get(theConditions);
49  }
50 
52  void initializeEvent(const edm::EventPrincipal * eventPrincipal, const edm::EventSetup * eventSetup)
53  {
54  theEventPrincipal = eventPrincipal;
55  eventSetup->get<HcalDbRecord>().get(theConditions);
57  }
58 
59  virtual void fill(edm::ModuleCallingContext const* mcc)
60  {
61 
62  theNoiseSignals.clear();
64  const COLLECTION * digis = 0;
65  // try accessing by whatever is set, Event or EventPrincipal
66  if(theEvent)
67  {
68  if( theEvent->getByToken(tok_, pDigis) ) {
69  digis = pDigis.product(); // get a ptr to the product
70  LogTrace("HcalSignalGenerator") << "total # digis for " << theInputTag << " " << digis->size();
71  }
72  else
73  {
74  throw cms::Exception("HcalSignalGenerator") << "Cannot find input data " << theInputTag;
75  }
76  }
77  else if(theEventPrincipal)
78  {
79  std::shared_ptr<edm::Wrapper<COLLECTION> const> digisPTR =
80  edm::getProductByTag<COLLECTION>(*theEventPrincipal, theInputTag, mcc );
81  if(digisPTR) {
82  digis = digisPTR->product();
83  }
84  }
85  else
86  {
87  throw cms::Exception("HcalSignalGenerator") << "No Event or EventPrincipal was set";
88  }
89 
90  if (digis)
91  {
92 
93  // loop over digis, adding these to the existing maps
94  for(typename COLLECTION::const_iterator it = digis->begin();
95  it != digis->end(); ++it)
96  {
97  // for the first signal, set the starting cap id
98  if((it == digis->begin()) && theElectronicsSim)
99  {
100  int startingCapId = (*it)[0].capid();
101  theElectronicsSim->setStartingCapId(startingCapId);
102  // theParameterMap->setFrameSize(it->id(), it->size()); //don't need this
103  }
104  if(validDigi(*it)) {
105  theNoiseSignals.push_back(samplesInPE(*it));
106  }
107  }
108  }
109  }
110 
111 private:
112 
113 
114  virtual void fillNoiseSignals(CLHEP::HepRandomEngine*) override {}
115  virtual void fillNoiseSignals() override {}
116 
117  bool validDigi(const DIGI & digi)
118  {
119  int DigiSum = 0;
120  for(int id = 0; id<digi.size(); id++) {
121  if(digi[id].adc() > 0) ++DigiSum;
122  }
123  return(DigiSum>0);
124  }
125 
126 
128  {
129 
130  // For PreMixing, (Note that modifications will need to be made for DataMixing) the
131  // energy for each channel is kept as fC*10, but stored as an integer in ADC. If this
132  // results in an overflow, the "standard" ADC conversion is used and that channel is marked
133  // with an error that allows the "standard" decoding to convert ADC back to fC. So, most
134  // channels get to fC by just dividing ADC/10; some require special treatment.
135 
136  // calibration, for future reference: (same block for all Hcal types)
137  HcalDetId cell = digi.id();
138  // const HcalCalibrations& calibrations=conditions->getHcalCalibrations(cell);
139  //const HcalQIECoder* channelCoder = theConditions->getHcalCoder (cell);
140  //const HcalQIEShape* channelShape = theConditions->getHcalShape (cell);
141  //HcalCoderDb coder (*channelCoder, *channelShape);
142  CaloSamples result = CaloSamples(cell,digi.size());;
143  //coder.adc2fC(digi, result);
144 
145  // first, check if there was an overflow in this fake digi:
146  bool overflow = false;
147  // find and list them
148 
149  for(int isample=0; isample<digi.size(); ++isample) {
150  if(digi[isample].er()) overflow = true;
151  }
152 
153  if(overflow) { // do full conversion, go back and overwrite fake entries
154 
155  const HcalQIECoder* channelCoder = theConditions->getHcalCoder (cell);
156  const HcalQIEShape* channelShape = theConditions->getHcalShape (cell);
157  HcalCoderDb coder (*channelCoder, *channelShape);
158  coder.adc2fC(digi, result);
159 
160  // overwrite with coded information
161  for(int isample=0; isample<digi.size(); ++isample) {
162  if(!digi[isample].er()) result[isample] = float(digi[isample].adc())/10.;
163  }
164  }
165  else { // saves creating the coder, etc., every time
166  // use coded information
167  for(int isample=0; isample<digi.size(); ++isample) {
168  result[isample] = float(digi[isample].adc())/10.;
169  }
170  result.setPresamples(digi.presamples());
171  }
172 
173  // std::cout << " HcalSignalGenerator: noise input ADC " << digi << std::endl;
174  // std::cout << " HcalSignalGenerator: noise input in fC " << result << std::endl;
175 
176  // translation done in fC, convert to pe:
177  fC2pe(result);
178 
179  return result;
180  }
181 
189 };
190 
195 
196 #endif
197 
int adc(sample_type sample)
get the ADC sample (12 bits)
edm::InputTag theInputTag
these come from the ParameterSet
tuple t
Definition: tree.py:139
void setStartingCapId(int startingCapId)
HcalSignalGenerator(const edm::InputTag &inputTag, const edm::EDGetTokenT< COLLECTION > &t)
void fC2pe(CaloSamples &samples) const
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:457
HCALDIGITIZERTRAITS::Digi DIGI
int size() const
total number of samples in the digi
Definition: HBHEDataFrame.h:26
std::vector< HBHEDataFrame >::const_iterator const_iterator
HCALDIGITIZERTRAITS::DigiCollection COLLECTION
virtual void fillNoiseSignals(CLHEP::HepRandomEngine *) override
const edm::Event * theEvent
these fields are set in initializeEvent()
CaloSamples samplesInPE(const DIGI &digi)
void initializeEvent(const edm::EventPrincipal *eventPrincipal, const edm::EventSetup *eventSetup)
some users use EventPrincipals, not Events. We support both
edm::ESHandle< HcalDbService > theConditions
std::vector< CaloSamples > theNoiseSignals
virtual void fill(edm::ModuleCallingContext const *mcc)
virtual void adc2fC(const HBHEDataFrame &df, CaloSamples &lf) const
Definition: HcalCoderDb.cc:44
const edm::EventPrincipal * theEventPrincipal
HcalSignalGenerator< HFDigitizerTraits > HFSignalGenerator
tuple result
Definition: query.py:137
HcalSimParameterMap * theParameterMap
void setPresamples(int pre)
set presample information
Definition: CaloSamples.cc:31
edm::EDGetTokenT< COLLECTION > tok_
How EventSelector::AcceptEvent() decides whether to accept an event for output otherwise it is excluding the probing of A single or multiple positive and the trigger will pass if any such matching triggers are PASS or EXCEPTION[A criterion thatmatches no triggers at all is detected and causes a throw.] A single negative with an expectation of appropriate bit checking in the decision and the trigger will pass if any such matching triggers are FAIL or EXCEPTION A wildcarded negative criterion that matches more than one trigger in the trigger but the state exists so we define the behavior If all triggers are the negative crieriion will lead to accepting the event(this again matches the behavior of"!*"before the partial wildcard feature was incorporated).The per-event"cost"of each negative criterion with multiple relevant triggers is about the same as!*was in the past
int presamples() const
number of samples before the sample from the triggered beam crossing (according to the hardware) ...
Definition: HBHEDataFrame.h:28
#define LogTrace(id)
HcalElectronicsSim * theElectronicsSim
const_iterator end() const
T const * product() const
Definition: Handle.h:81
const T & get() const
Definition: EventSetup.h:55
T const * product() const
Definition: ESHandle.h:86
HcalSignalGenerator< HODigitizerTraits > HOSignalGenerator
size_type size() const
HcalSignalGenerator< ZDCDigitizerTraits > ZDCSignalGenerator
virtual void fillNoiseSignals() override
HcalSignalGenerator< HBHEDigitizerTraits > HBHESignalGenerator
const HcalDetId & id() const
Definition: HBHEDataFrame.h:22
bool validDigi(const DIGI &digi)
void initializeEvent(const edm::Event *event, const edm::EventSetup *eventSetup)
void setDbService(const HcalDbService *service)
const_iterator begin() const