CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
List of all members | Public Member Functions | Private Member Functions | Private Attributes | Static Private Attributes
sistrip::FEDEmulatorModule Class Reference
Inheritance diagram for sistrip::FEDEmulatorModule:
edm::EDProducer edm::ProducerBase edm::EDConsumerBase edm::ProductRegistryHelper

Public Member Functions

 FEDEmulatorModule (const edm::ParameterSet &)
 
 ~FEDEmulatorModule ()
 
- Public Member Functions inherited from edm::EDProducer
 EDProducer ()
 
virtual ~EDProducer ()
 
- Public Member Functions inherited from edm::ProducerBase
 ProducerBase ()
 
void registerProducts (ProducerBase *, ProductRegistry *, ModuleDescription const &)
 
std::function< void(BranchDescription
const &)> 
registrationCallback () const
 used by the fwk to register list of products More...
 
virtual ~ProducerBase ()
 
- Public Member Functions inherited from edm::EDConsumerBase
 EDConsumerBase ()
 
ProductHolderIndex indexFrom (EDGetToken, BranchType, TypeID const &) const
 
void itemsMayGet (BranchType, std::vector< ProductHolderIndex > &) const
 
void itemsToGet (BranchType, std::vector< ProductHolderIndex > &) const
 
void labelsForToken (EDGetToken iToken, Labels &oLabels) const
 
void updateLookup (BranchType iBranchType, ProductHolderIndexHelper const &)
 
virtual ~EDConsumerBase ()
 

Private Member Functions

virtual void produce (edm::Event &, const edm::EventSetup &) override
 

Private Attributes

std::auto_ptr
< SiStripRawProcessingAlgorithms
algorithms_
 object for zero-suppression More...
 
bool byModule_
 
sistrip::FEDEmulator fedEmulator_
 
edm::InputTag spyReorderedDigisTag_
 
edm::InputTag spyVirginRawDigisTag_
 
SpyUtilities utility_
 

Static Private Attributes

static const char * messageLabel_ = "SiStripFEDEmulatorModule"
 

Additional Inherited Members

- Public Types inherited from edm::EDProducer
typedef EDProducer ModuleType
 
typedef WorkerT< EDProducerWorkerType
 
- Public Types inherited from edm::ProducerBase
typedef
ProductRegistryHelper::TypeLabelList 
TypeLabelList
 
- Static Public Member Functions inherited from edm::EDProducer
static const std::string & baseType ()
 
static void fillDescriptions (ConfigurationDescriptions &descriptions)
 
static void prevalidate (ConfigurationDescriptions &descriptions)
 
- Protected Member Functions inherited from edm::EDProducer
CurrentProcessingContext const * currentContext () const
 
- Protected Member Functions inherited from edm::ProducerBase
void callWhenNewProductsRegistered (std::function< void(BranchDescription const &)> const &func)
 
- Protected Member Functions inherited from edm::EDConsumerBase
template<typename ProductType , BranchType B = InEvent>
EDGetTokenT< ProductType > consumes (edm::InputTag const &tag)
 
EDGetToken consumes (const TypeToGet &id, edm::InputTag const &tag)
 
template<BranchType B>
EDGetToken consumes (TypeToGet const &id, edm::InputTag const &tag)
 
ConsumesCollector consumesCollector ()
 Use a ConsumesCollector to gather consumes information from helper functions. More...
 
template<typename ProductType , BranchType B = InEvent>
void consumesMany ()
 
void consumesMany (const TypeToGet &id)
 
template<BranchType B>
void consumesMany (const TypeToGet &id)
 
template<typename ProductType , BranchType B = InEvent>
EDGetTokenT< ProductType > mayConsume (edm::InputTag const &tag)
 
EDGetToken mayConsume (const TypeToGet &id, edm::InputTag const &tag)
 
template<BranchType B>
EDGetToken mayConsume (const TypeToGet &id, edm::InputTag const &tag)
 

Detailed Description

Definition at line 58 of file SiStripFEDEmulatorModule.cc.

Constructor & Destructor Documentation

sistrip::FEDEmulatorModule::FEDEmulatorModule ( const edm::ParameterSet iConfig)
explicit

Definition at line 98 of file SiStripFEDEmulatorModule.cc.

References byModule_, fedEmulator_, and sistrip::FEDEmulator::initialise().

98  :
99  spyReorderedDigisTag_(iConfig.getParameter<edm::InputTag>("SpyReorderedDigisTag")),
100  spyVirginRawDigisTag_(iConfig.getParameter<edm::InputTag>("SpyVirginRawDigisTag")),
101  byModule_(iConfig.getParameter<bool>("ByModule")),
103  {
104 
106 
107  if (!byModule_) { //if not by module
108  //the medians will be produced by fed id/channel
109  produces<std::map<uint32_t,std::vector<uint32_t> > >("Medians");
110  produces<edm::DetSetVector<SiStripRawDigi> >("PedestalsOrdered");
111  produces<edm::DetSetVector<SiStripProcessedRawDigi> >("NoisesOrdered");
112  produces<edm::DetSetVector<SiStripRawDigi> >("PedSubtrDigisOrdered");
113  produces<edm::DetSetVector<SiStripRawDigi> >("CMSubtrDigisOrdered");
114  }
115  else { //by module
116  produces<edm::DetSetVector<SiStripRawDigi> >("ModulePedestals");
117  produces<edm::DetSetVector<SiStripProcessedRawDigi> >("ModuleNoises");
118  produces<edm::DetSetVector<SiStripRawDigi> >("PedSubtrModuleDigis");
119  produces<std::map<uint32_t,std::vector<uint32_t> > >("ModuleMedians");
120  produces<edm::DetSetVector<SiStripRawDigi> >("CMSubtrModuleDigis");
121  produces<edm::DetSetVector<SiStripDigi> >("ZSModuleDigis");
122  }//end of by module check
123 
124  }//end of FEDEmulatorModule constructor
T getParameter(std::string const &) const
std::auto_ptr< SiStripRawProcessingAlgorithms > algorithms_
object for zero-suppression
static std::auto_ptr< SiStripRawProcessingAlgorithms > create(const edm::ParameterSet &)
void initialise(const bool byModule)
sistrip::FEDEmulatorModule::~FEDEmulatorModule ( )

Definition at line 126 of file SiStripFEDEmulatorModule.cc.

127  {
128  }

Member Function Documentation

void sistrip::FEDEmulatorModule::produce ( edm::Event iEvent,
const edm::EventSetup iSetup 
)
overrideprivatevirtual

Implements edm::EDProducer.

Definition at line 132 of file SiStripFEDEmulatorModule.cc.

References algorithms_, FedChannelConnection::apvPairNumber(), edm::DetSetVector< T >::begin(), byModule_, SiStripFedCabling::connection(), gather_cfg::cout, FedChannelConnection::detId(), alignCSCRings::e, edm::DetSetVector< T >::end(), fedEmulator_, sistrip::SpyUtilities::fedIndex(), edm::Event::getByLabel(), sistrip::SpyUtilities::getCabling(), sistrip::SpyUtilities::getNoiseHandle(), sistrip::SpyUtilities::getPedestalHandle(), sistrip::FEDEmulator::initialiseModule(), Association::map, FedChannelConnection::nApvPairs(), edm::Handle< T >::product(), edm::Event::put(), sistrip::FEDEmulator::retrieveNoises(), sistrip::FEDEmulator::retrievePedestals(), edm::DetSet< T >::size(), edm::DetSetVector< T >::size(), spyReorderedDigisTag_, spyVirginRawDigisTag_, sistrip::STRIPS_PER_FEDCH, sistrip::FEDEmulator::subtractCM(), sistrip::FEDEmulator::subtractPedestals(), utility_, cms::Exception::what(), and sistrip::FEDEmulator::zeroSuppress().

Referenced by JSONExport.JsonExport::export(), HTMLExport.HTMLExport::export(), and HTMLExport.HTMLExportStatic::export().

133  {
134  //update cabling and pedestals
135  const SiStripFedCabling* lCabling = utility_.getCabling( iSetup );
138 
139  //initialise the algorithms object for the zero suppression
140  algorithms_->initialize(iSetup);
141 
142  //retrieve the digis
144  try { //to get the digis from the event
145  if (!byModule_) {
146  iEvent.getByLabel(spyReorderedDigisTag_, lDigisHandle);
147  }
148  else { //digis supplied by module
149  iEvent.getByLabel(spyVirginRawDigisTag_, lDigisHandle);
150  }//end of by module check
151  } catch (const cms::Exception& e) {
152  std::cout << e.what() ;
153  return;
154  } //end of get digis try
155 
156  const edm::DetSetVector<SiStripRawDigi> * lInputDigis = lDigisHandle.product();
157 
158  unsigned int lNDigis = lInputDigis->size();
159 
160  //define output containers
161  //reserve space, will push_back elements
162  std::vector<edm::DetSetVector<SiStripRawDigi>::detset > pedsData;
163  pedsData.reserve(lNDigis);
164  std::vector<edm::DetSetVector<SiStripProcessedRawDigi>::detset > noiseData;
165  noiseData.reserve(lNDigis);
166  std::vector<edm::DetSetVector<SiStripRawDigi>::detset > pedSubtrData;
167  pedSubtrData.reserve(lNDigis);
168  std::vector<edm::DetSetVector<SiStripRawDigi>::detset > cmSubtrData;
169  cmSubtrData.reserve(lNDigis);
170  //zero suppressed contained - no fixed size (could be empty) so no need to reserve elements.
171  std::vector< edm::DetSet<SiStripDigi> > zsData;
172 
173  //this is a map: no reserve/resize
174  std::map<uint32_t,std::vector<uint32_t> > medsData;
175 
176  edm::DetSetVector<SiStripRawDigi>::const_iterator inputChannel = lInputDigis->begin();
177 
178  for ( ; inputChannel!=lInputDigis->end(); ++inputChannel){//loop on input channels
179  uint32_t lDetId = inputChannel->detId(); //either fedIndex or detId
180 
181  pedsData.push_back( edm::DetSetVector<SiStripRawDigi>::detset(lDetId) );
182  noiseData.push_back( edm::DetSetVector<SiStripProcessedRawDigi>::detset(lDetId) );
183  pedSubtrData.push_back(edm::DetSetVector<SiStripRawDigi>::detset(lDetId) );
184  cmSubtrData.push_back( edm::DetSetVector<SiStripRawDigi>::detset(lDetId) );
185 
186  unsigned int lNStrips = inputChannel->size();
187 
188  //define output digi containers
189  std::vector<SiStripRawDigi>& pedsDetSetData = pedsData.back().data;
190  pedsDetSetData.reserve(lNStrips);
191  std::vector<SiStripProcessedRawDigi>& noiseDetSetData = noiseData.back().data;
192  noiseDetSetData.reserve(lNStrips);
193  std::vector<SiStripRawDigi>& pedSubtrDetSetData = pedSubtrData.back().data;
194  pedSubtrDetSetData.reserve(lNStrips);
195  std::vector<SiStripRawDigi>& cmSubtrDetSetData = cmSubtrData.back().data;
196  cmSubtrDetSetData.reserve(lNStrips);
197  //zero suppressed - slightly different procedure as not fixed size
198  edm::DetSet<SiStripDigi> zsDetSetData(lDetId);
199 
200  //determine the number of APV pairs in the channel
201  uint32_t lNPairs = static_cast<uint32_t>(lNStrips*1./sistrip::STRIPS_PER_FEDCH);
202  uint32_t lPair = 0;
203 
204  std::vector<uint32_t> medsDetSetData;
205  medsDetSetData.reserve(lNPairs*2); //2*number of pairs per module. If not by module, lNPairs = 1...
206 
207  if (!byModule_) { //the input is not stored by module
208  //need to retrieve the proper detId from cabling
209  uint16_t lFedId = 0;
210  uint16_t lFedChannel = 0;
211  sistrip::SpyUtilities::fedIndex(lDetId, lFedId, lFedChannel);
212 
213  const FedChannelConnection & lConnection = lCabling->connection(lFedId,lFedChannel);
214  lDetId = lConnection.detId();
215  lNPairs = lConnection.nApvPairs();
216  lPair = lConnection.apvPairNumber();
217  }//end of by module check
218 
219  fedEmulator_.initialiseModule(lDetId,lNPairs,lPair);
220 
221  //get the pedestal values
222  //stored by module in the database
223  fedEmulator_.retrievePedestals(lPedsHandle);
224  fedEmulator_.retrieveNoises(lNoiseHandle);
225 
226  //last option: fill medians from these ped subtr data
227  //if want something else, need to call a method to fill
228  //the data member medians_ of the class fedEmulator.
229  fedEmulator_.subtractPedestals(inputChannel,
230  pedsDetSetData,
231  noiseDetSetData,
232  pedSubtrDetSetData,
233  medsDetSetData,
234  true);
235 
236  fedEmulator_.subtractCM(pedSubtrDetSetData,cmSubtrDetSetData);
237 
238  //fill the median map
239  medsData[inputChannel->detId()] = medsDetSetData;
240 
241  //zero suppress the digis
242  fedEmulator_.zeroSuppress(cmSubtrDetSetData, zsDetSetData, algorithms_);
243  if (zsDetSetData.size()) zsData.push_back( zsDetSetData );
244 
245  }//loop on input channels
246 
247 
248  std::auto_ptr<edm::DetSetVector<SiStripRawDigi> > lPeds(new edm::DetSetVector<SiStripRawDigi>(pedsData,true));
249  std::auto_ptr<edm::DetSetVector<SiStripProcessedRawDigi> > lNoises(new edm::DetSetVector<SiStripProcessedRawDigi>(noiseData,true));
250 
251  std::auto_ptr<edm::DetSetVector<SiStripRawDigi> > lOutputPedSubtr(new edm::DetSetVector<SiStripRawDigi>(pedSubtrData,true));
252 
253  std::auto_ptr<edm::DetSetVector<SiStripRawDigi> > lOutputCMSubtr(new edm::DetSetVector<SiStripRawDigi>(cmSubtrData,true));
254 
255  std::auto_ptr<std::map<uint32_t,std::vector<uint32_t> > > lMedians(new std::map<uint32_t,std::vector<uint32_t> >(medsData));
256 
257  //zero suppressed digis
258  std::auto_ptr< edm::DetSetVector<SiStripDigi> > lOutputZS(new edm::DetSetVector<SiStripDigi>(zsData));
259 
260  if (!byModule_) {
261  iEvent.put(lMedians,"Medians");
262  iEvent.put(lPeds,"PedestalsOrdered");
263  iEvent.put(lNoises,"NoisesOrdered");
264  iEvent.put(lOutputPedSubtr,"PedSubtrDigisOrdered");
265  iEvent.put(lOutputCMSubtr,"CMSubtrDigisOrdered");
266  }
267  else {
268  iEvent.put(lPeds,"ModulePedestals");
269  iEvent.put(lNoises,"ModuleNoises");
270  iEvent.put(lOutputPedSubtr,"PedSubtrModuleDigis");
271  iEvent.put(lMedians,"ModuleMedians");
272  iEvent.put(lOutputCMSubtr,"CMSubtrModuleDigis");
273  iEvent.put(lOutputZS,"ZSModuleDigis");
274  }
275 
276  }//produce method
void zeroSuppress(const std::vector< SiStripRawDigi > &cmSubtrDetSetData, edm::DetSet< SiStripDigi > &zsDetSetData, const std::auto_ptr< SiStripRawProcessingAlgorithms > &algorithms)
virtual char const * what() const
Definition: Exception.cc:141
static void fedIndex(uint32_t aFedIndex, uint16_t &aFedId, uint16_t &aFedChannel)
void subtractPedestals(const edm::DetSetVector< SiStripRawDigi >::const_iterator &inputChannel, std::vector< SiStripRawDigi > &pedsDetSetData, std::vector< SiStripProcessedRawDigi > &noiseDetSetData, std::vector< SiStripRawDigi > &pedSubtrDetSetData, std::vector< uint32_t > &medsDetSetData, const bool fillApvsForCM)
edm::ESHandle< SiStripNoises > getNoiseHandle(const edm::EventSetup &eventSetup)
uint16_t apvPairNumber() const
std::auto_ptr< SiStripRawProcessingAlgorithms > algorithms_
object for zero-suppression
edm::ESHandle< SiStripPedestals > getPedestalHandle(const edm::EventSetup &eventSetup)
const FedChannelConnection & connection(uint16_t fed_id, uint16_t fed_ch) const
void retrieveNoises(const edm::ESHandle< SiStripNoises > &aHandle)
dictionary map
Definition: Association.py:205
const uint32_t & detId() const
OrphanHandle< PROD > put(std::auto_ptr< PROD > product)
Put a new product.
Definition: Event.h:94
Class containning control, module, detector and connection information, at the level of a FED channel...
void initialiseModule(const uint32_t aDetId, const uint32_t aNPairs, const uint32_t aPair)
void subtractCM(const std::vector< SiStripRawDigi > &pedSubtrDetSetData, std::vector< SiStripRawDigi > &cmSubtrDetSetData)
bool getByLabel(InputTag const &tag, Handle< PROD > &result) const
Definition: Event.h:361
iterator end()
Return the off-the-end iterator.
Definition: DetSetVector.h:356
size_type size() const
Return the number of contained DetSets.
Definition: DetSetVector.h:278
static const uint16_t STRIPS_PER_FEDCH
const SiStripFedCabling * getCabling(const edm::EventSetup &)
Updates the cabling object from the DB.
const uint16_t & nApvPairs() const
T const * product() const
Definition: Handle.h:74
Contains cabling info at the device level, including DetId, APV pair numbers, hardware addresses...
tuple cout
Definition: gather_cfg.py:121
iterator begin()
Return an iterator to the first DetSet.
Definition: DetSetVector.h:341
void retrievePedestals(const edm::ESHandle< SiStripPedestals > &aHandle)
collection_type::const_iterator const_iterator
Definition: DetSetVector.h:106

Member Data Documentation

std::auto_ptr<SiStripRawProcessingAlgorithms> sistrip::FEDEmulatorModule::algorithms_
private

object for zero-suppression

Definition at line 81 of file SiStripFEDEmulatorModule.cc.

Referenced by produce().

bool sistrip::FEDEmulatorModule::byModule_
private

Definition at line 75 of file SiStripFEDEmulatorModule.cc.

Referenced by FEDEmulatorModule(), and produce().

sistrip::FEDEmulator sistrip::FEDEmulatorModule::fedEmulator_
private

Definition at line 77 of file SiStripFEDEmulatorModule.cc.

Referenced by FEDEmulatorModule(), and produce().

const char * sistrip::FEDEmulatorModule::messageLabel_ = "SiStripFEDEmulatorModule"
staticprivate

Definition at line 79 of file SiStripFEDEmulatorModule.cc.

edm::InputTag sistrip::FEDEmulatorModule::spyReorderedDigisTag_
private

Definition at line 71 of file SiStripFEDEmulatorModule.cc.

Referenced by produce().

edm::InputTag sistrip::FEDEmulatorModule::spyVirginRawDigisTag_
private

Definition at line 72 of file SiStripFEDEmulatorModule.cc.

Referenced by produce().

SpyUtilities sistrip::FEDEmulatorModule::utility_
private

Definition at line 84 of file SiStripFEDEmulatorModule.cc.

Referenced by produce().