CMS 3D CMS Logo

List of all members | Public Member Functions | Private Types | Private Member Functions | Private Attributes
SiStripDigitizer Class Reference

Accumulator to perform digitisation on the strip tracker sim hits. More...

#include <SiStripDigitizer.h>

Inheritance diagram for SiStripDigitizer:
DigiAccumulatorMixMod

Public Member Functions

void accumulate (edm::Event const &e, edm::EventSetup const &c) override
 
void accumulate (PileUpEventPrincipal const &e, edm::EventSetup const &c, edm::StreamID const &) override
 
void finalizeEvent (edm::Event &e, edm::EventSetup const &c) override
 
PileupMixingContentgetEventPileupInfo () override
 
void initializeEvent (edm::Event const &e, edm::EventSetup const &c) override
 
 SiStripDigitizer (const edm::ParameterSet &conf, edm::ProducerBase &mixMod, edm::ConsumesCollector &iC)
 
void StorePileupInformation (std::vector< int > &numInteractionList, std::vector< int > &bunchCrossingList, std::vector< float > &TrueInteractionList, std::vector< edm::EventID > &eventInfoList, int bunchSpacing) override
 
 ~SiStripDigitizer () override
 
- Public Member Functions inherited from DigiAccumulatorMixMod
virtual void beginLuminosityBlock (edm::LuminosityBlock const &lumi, edm::EventSetup const &setup)
 
virtual void beginRun (edm::Run const &run, edm::EventSetup const &setup)
 
 DigiAccumulatorMixMod ()
 
virtual void endLuminosityBlock (edm::LuminosityBlock const &lumi, edm::EventSetup const &setup)
 
virtual void endRun (edm::Run const &run, edm::EventSetup const &setup)
 
virtual void finalizeBunchCrossing (edm::Event &event, edm::EventSetup const &setup, int bunchCrossing)
 
virtual void initializeBunchCrossing (edm::Event const &event, edm::EventSetup const &setup, int bunchCrossing)
 
virtual ~DigiAccumulatorMixMod ()
 

Private Types

typedef std::map< unsigned int, std::vector< std::pair< const PSimHit *, int > >, std::less< unsigned int > > simhit_map
 
typedef simhit_map::iterator simhit_map_iterator
 
typedef std::vector< std::string > vstring
 

Private Member Functions

void accumulateStripHits (edm::Handle< std::vector< PSimHit >>, const TrackerTopology *tTopo, size_t globalSimHitIndex, const unsigned int tofBin)
 

Private Attributes

std::map< std::string, size_t > crossingSimHitIndexOffset_
 Offset to add to the index of each sim hit to account for which crossing it's in. More...
 
std::map< unsigned int, StripGeomDetUnit const * > detectorUnits
 
const double fracOfEventsToSimAPV_
 Whether or not to create the association to sim truth collection. Set in configuration. More...
 
const std::string gainLabel
 
const std::string geometryType
 
const std::string hitsProducer
 
const bool includeAPVSimulation_
 
const bool makeDigiSimLinks_
 
edm::ESHandle< TrackerGeometrypDD
 
std::unique_ptr< PileupMixingContentPileupInfo_
 
const std::string PRDigi
 
edm::ESHandle< MagneticFieldpSetup
 
CLHEP::HepRandomEngine * randomEngine_ = nullptr
 
const std::string SCDigi
 
std::vector< std::pair< int, std::bitset< 6 > > > theAffectedAPVvector
 
std::map< uint32_t, std::vector< int > > theDetIdList
 
std::unique_ptr< SiStripDigitizerAlgorithmtheDigiAlgo
 
const vstring trackerContainers
 
const bool useConfFromDB
 
const std::string VRDigi
 
const bool zeroSuppression
 
const std::string ZSDigi
 

Detailed Description

Accumulator to perform digitisation on the strip tracker sim hits.

Author
original author unknown; converted from a producer to a MixingModule accumulator by Bill Tanenbaum; functionality to create digi-sim links moved from Bill's DigiSimLinkProducer into here by Mark Grimes (mark..nosp@m.grim.nosp@m.es@br.nosp@m.isto.nosp@m.l.ac..nosp@m.uk).
Date
original date unknown; moved into a MixingModule accumulator mid to late 2012; digi sim links eventually finished May 2013

Definition at line 45 of file SiStripDigitizer.h.

Member Typedef Documentation

typedef std::map<unsigned int, std::vector<std::pair<const PSimHit*, int> >, std::less<unsigned int> > SiStripDigitizer::simhit_map
private

Definition at line 74 of file SiStripDigitizer.h.

typedef simhit_map::iterator SiStripDigitizer::simhit_map_iterator
private

Definition at line 75 of file SiStripDigitizer.h.

typedef std::vector<std::string> SiStripDigitizer::vstring
private

Definition at line 73 of file SiStripDigitizer.h.

Constructor & Destructor Documentation

SiStripDigitizer::SiStripDigitizer ( const edm::ParameterSet conf,
edm::ProducerBase mixMod,
edm::ConsumesCollector iC 
)
explicit

Definition at line 60 of file SiStripDigitizer.cc.

References egammaCTFFinalFitWithMaterial_cff::alias, edm::ConsumesCollector::consumes(), Exception, hitsProducer, PRDigi, edm::ProductRegistryHelper::produces(), SCDigi, AlCaHLTBitMon_QueryRunRegistry::string, GlobalPosition_Frontier_DevDB_cff::tag, theDigiAlgo, trackerContainers, VRDigi, and ZSDigi.

61  : gainLabel(conf.getParameter<std::string>("Gain")),
62  hitsProducer(conf.getParameter<std::string>("hitsProducer")),
63  trackerContainers(conf.getParameter<std::vector<std::string>>("ROUList")),
64  ZSDigi(conf.getParameter<edm::ParameterSet>("DigiModeList").getParameter<std::string>("ZSDigi")),
65  SCDigi(conf.getParameter<edm::ParameterSet>("DigiModeList").getParameter<std::string>("SCDigi")),
66  VRDigi(conf.getParameter<edm::ParameterSet>("DigiModeList").getParameter<std::string>("VRDigi")),
67  PRDigi(conf.getParameter<edm::ParameterSet>("DigiModeList").getParameter<std::string>("PRDigi")),
68  geometryType(conf.getParameter<std::string>("GeometryType")),
69  useConfFromDB(conf.getParameter<bool>("TrackerConfigurationFromDB")),
70  zeroSuppression(conf.getParameter<bool>("ZeroSuppression")),
71  makeDigiSimLinks_(conf.getUntrackedParameter<bool>("makeDigiSimLinks", false)),
72  includeAPVSimulation_(conf.getParameter<bool>("includeAPVSimulation")),
73  fracOfEventsToSimAPV_(conf.getParameter<double>("fracOfEventsToSimAPV")) {
74  const std::string alias("simSiStripDigis");
75 
76  mixMod.produces<edm::DetSetVector<SiStripDigi>>(ZSDigi).setBranchAlias(ZSDigi);
79  mixMod.produces<edm::DetSetVector<SiStripRawDigi>>("StripAmplitudes").setBranchAlias(alias + "StripAmplitudes");
80  mixMod.produces<edm::DetSetVector<SiStripRawDigi>>("StripAmplitudesPostAPV")
81  .setBranchAlias(alias + "StripAmplitudesPostAPV");
82  mixMod.produces<edm::DetSetVector<SiStripRawDigi>>("StripAPVBaselines").setBranchAlias(alias + "StripAPVBaselines");
84  mixMod.produces<edm::DetSetVector<StripDigiSimLink>>().setBranchAlias(alias + "siStripDigiSimLink");
85  mixMod.produces<bool>("SimulatedAPVDynamicGain").setBranchAlias(alias + "SimulatedAPVDynamicGain");
86  mixMod.produces<std::vector<std::pair<int, std::bitset<6>>>>("AffectedAPVList").setBranchAlias(alias + "AffectedAPV");
87  for (auto const& trackerContainer : trackerContainers) {
88  edm::InputTag tag(hitsProducer, trackerContainer);
89  iC.consumes<std::vector<PSimHit>>(edm::InputTag(hitsProducer, trackerContainer));
90  }
92  if (!rng.isAvailable()) {
93  throw cms::Exception("Configuration")
94  << "SiStripDigitizer requires the RandomNumberGeneratorService\n"
95  "which is not present in the configuration file. You must add the service\n"
96  "in the configuration file or remove the modules that require it.";
97  }
98  theDigiAlgo.reset(new SiStripDigitizerAlgorithm(conf));
99 }
BranchAliasSetterT< ProductType > produces()
declare what type of product will make and with which optional label
const vstring trackerContainers
EDGetTokenT< ProductType > consumes(edm::InputTag const &tag)
T getParameter(std::string const &) const
const std::string ZSDigi
T getUntrackedParameter(std::string const &, T const &) const
const bool zeroSuppression
const std::string hitsProducer
const bool useConfFromDB
const bool includeAPVSimulation_
std::unique_ptr< SiStripDigitizerAlgorithm > theDigiAlgo
const std::string VRDigi
const std::string PRDigi
const std::string geometryType
const double fracOfEventsToSimAPV_
Whether or not to create the association to sim truth collection. Set in configuration.
const bool makeDigiSimLinks_
const std::string gainLabel
const std::string SCDigi
SiStripDigitizer::~SiStripDigitizer ( )
override

Definition at line 102 of file SiStripDigitizer.cc.

102 {}

Member Function Documentation

void SiStripDigitizer::accumulate ( edm::Event const &  e,
edm::EventSetup const &  c 
)
overridevirtual

Implements DigiAccumulatorMixMod.

Definition at line 135 of file SiStripDigitizer.cc.

References accumulateStripHits(), crossingSimHitIndexOffset_, edm::InputTag::encode(), edm::EventSetup::get(), edm::Event::getByLabel(), StripDigiSimLink::HighTof, hitsProducer, edm::HandleBase::isValid(), StripDigiSimLink::LowTof, edm::ESHandle< T >::product(), trackerHits::simHits, AlCaHLTBitMon_QueryRunRegistry::string, GlobalPosition_Frontier_DevDB_cff::tag, and trackerContainers.

135  {
136  //Retrieve tracker topology from geometry
138  iSetup.get<TrackerTopologyRcd>().get(tTopoHand);
139  const TrackerTopology* tTopo = tTopoHand.product();
140 
141  // Step A: Get Inputs
142  for (auto const& trackerContainer : trackerContainers) {
144  edm::InputTag tag(hitsProducer, trackerContainer);
145  unsigned int tofBin = StripDigiSimLink::LowTof;
146  if (trackerContainer.find(std::string("HighTof")) != std::string::npos)
147  tofBin = StripDigiSimLink::HighTof;
148 
149  iEvent.getByLabel(tag, simHits);
150  accumulateStripHits(simHits, tTopo, crossingSimHitIndexOffset_[tag.encode()], tofBin);
151  // Now that the hits have been processed, I'll add the amount of hits in this crossing on to
152  // the global counter. Next time accumulateStripHits() is called it will count the sim hits
153  // as though they were on the end of this collection.
154  // Note that this is only used for creating digi-sim links (if configured to do so).
155  if (simHits.isValid())
156  crossingSimHitIndexOffset_[tag.encode()] += simHits->size();
157  }
158 }
const vstring trackerContainers
const std::string hitsProducer
int iEvent
Definition: GenABIO.cc:224
void accumulateStripHits(edm::Handle< std::vector< PSimHit >>, const TrackerTopology *tTopo, size_t globalSimHitIndex, const unsigned int tofBin)
bool isValid() const
Definition: HandleBase.h:74
std::map< std::string, size_t > crossingSimHitIndexOffset_
Offset to add to the index of each sim hit to account for which crossing it&#39;s in. ...
T const * product() const
Definition: ESHandle.h:86
void SiStripDigitizer::accumulate ( PileUpEventPrincipal const &  e,
edm::EventSetup const &  c,
edm::StreamID const &  streamID 
)
overridevirtual

Implements DigiAccumulatorMixMod.

Definition at line 160 of file SiStripDigitizer.cc.

References accumulateStripHits(), crossingSimHitIndexOffset_, edm::InputTag::encode(), edm::EventSetup::get(), PileUpEventPrincipal::getByLabel(), StripDigiSimLink::HighTof, hitsProducer, edm::HandleBase::isValid(), StripDigiSimLink::LowTof, PileupInfo_, edm::ESHandle< T >::product(), trackerHits::simHits, AlCaHLTBitMon_QueryRunRegistry::string, GlobalPosition_Frontier_DevDB_cff::tag, theDigiAlgo, and trackerContainers.

162  {
164  iSetup.get<TrackerTopologyRcd>().get(tTopoHand);
165  const TrackerTopology* tTopo = tTopoHand.product();
166 
167  //Re-compute luminosity for accumulation for HIP effects
168  theDigiAlgo->calculateInstlumiScale(PileupInfo_.get());
169 
170  // Step A: Get Inputs
171  for (auto const& trackerContainer : trackerContainers) {
173  edm::InputTag tag(hitsProducer, trackerContainer);
174  unsigned int tofBin = StripDigiSimLink::LowTof;
175  if (trackerContainer.find(std::string("HighTof")) != std::string::npos)
176  tofBin = StripDigiSimLink::HighTof;
177 
178  iEvent.getByLabel(tag, simHits);
179  accumulateStripHits(simHits, tTopo, crossingSimHitIndexOffset_[tag.encode()], tofBin);
180  // Now that the hits have been processed, I'll add the amount of hits in this crossing on to
181  // the global counter. Next time accumulateStripHits() is called it will count the sim hits
182  // as though they were on the end of this collection.
183  // Note that this is only used for creating digi-sim links (if configured to do so).
184  if (simHits.isValid())
185  crossingSimHitIndexOffset_[tag.encode()] += simHits->size();
186  }
187 }
const vstring trackerContainers
const std::string hitsProducer
int iEvent
Definition: GenABIO.cc:224
void accumulateStripHits(edm::Handle< std::vector< PSimHit >>, const TrackerTopology *tTopo, size_t globalSimHitIndex, const unsigned int tofBin)
bool isValid() const
Definition: HandleBase.h:74
std::unique_ptr< SiStripDigitizerAlgorithm > theDigiAlgo
std::map< std::string, size_t > crossingSimHitIndexOffset_
Offset to add to the index of each sim hit to account for which crossing it&#39;s in. ...
T const * product() const
Definition: ESHandle.h:86
std::unique_ptr< PileupMixingContent > PileupInfo_
void SiStripDigitizer::accumulateStripHits ( edm::Handle< std::vector< PSimHit >>  hSimHits,
const TrackerTopology tTopo,
size_t  globalSimHitIndex,
const unsigned int  tofBin 
)
private

Definition at line 104 of file SiStripDigitizer.cc.

References detectorUnits, MagneticField::inTesla(), GeomDetEnumerators::isTrackerStrip(), LogDebug, pSetup, randomEngine_, trackerHits::simHits, and theDigiAlgo.

Referenced by accumulate().

107  {
108  // globalSimHitIndex is the index the sim hit will have when it is put in a collection
109  // of sim hits for all crossings. This is only used when creating digi-sim links if
110  // configured to do so.
111 
112  if (hSimHits.isValid()) {
113  std::set<unsigned int> detIds;
114  std::vector<PSimHit> const& simHits = *hSimHits.product();
115  for (std::vector<PSimHit>::const_iterator it = simHits.begin(), itEnd = simHits.end(); it != itEnd;
116  ++it, ++globalSimHitIndex) {
117  unsigned int detId = (*it).detUnitId();
118  if (detIds.insert(detId).second) {
119  // The insert succeeded, so this detector element has not yet been processed.
120  assert(detectorUnits[detId]);
121  if (detectorUnits[detId]->type().isTrackerStrip()) { // this test can be removed and replaced by stripdet!=0
122  auto stripdet = detectorUnits[detId];
123  //access to magnetic field in global coordinates
124  GlobalVector bfield = pSetup->inTesla(stripdet->surface().position());
125  LogDebug("Digitizer ") << "B-field(T) at " << stripdet->surface().position()
126  << "(cm): " << pSetup->inTesla(stripdet->surface().position());
127  theDigiAlgo->accumulateSimHits(it, itEnd, globalSimHitIndex, tofBin, stripdet, bfield, tTopo, randomEngine_);
128  }
129  }
130  } // end of loop over sim hits
131  }
132 }
#define LogDebug(id)
type
Definition: HCALResponse.h:21
std::map< unsigned int, StripGeomDetUnit const * > detectorUnits
CLHEP::HepRandomEngine * randomEngine_
bool isValid() const
Definition: HandleBase.h:74
virtual GlobalVector inTesla(const GlobalPoint &gp) const =0
Field value ad specified global point, in Tesla.
bool isTrackerStrip(GeomDetEnumerators::SubDetector m)
std::unique_ptr< SiStripDigitizerAlgorithm > theDigiAlgo
T const * product() const
Definition: Handle.h:74
edm::ESHandle< MagneticField > pSetup
void SiStripDigitizer::finalizeEvent ( edm::Event e,
edm::EventSetup const &  c 
)
overridevirtual

Implements DigiAccumulatorMixMod.

Definition at line 231 of file SiStripDigitizer.cc.

References TrackerGeometry::detUnits(), fracOfEventsToSimAPV_, gainLabel, edm::EventSetup::get(), includeAPVSimulation_, makeDigiSimLinks_, eostools::move(), convertSQLitetoXML_cfg::output, pDD, PRDigi, edm::ESHandle< T >::product(), edm::Event::put(), randomEngine_, SCDigi, theAffectedAPVvector, theDetIdList, theDigiAlgo, useConfFromDB, VRDigi, zeroSuppression, and ZSDigi.

231  {
232  edm::ESHandle<SiStripGain> gainHandle;
233  edm::ESHandle<SiStripNoises> noiseHandle;
234  edm::ESHandle<SiStripThreshold> thresholdHandle;
235  edm::ESHandle<SiStripPedestals> pedestalHandle;
236  edm::ESHandle<SiStripApvSimulationParameters> apvSimulationParametersHandle;
237  iSetup.get<SiStripGainSimRcd>().get(gainLabel, gainHandle);
238  iSetup.get<SiStripNoisesRcd>().get(noiseHandle);
239  iSetup.get<SiStripThresholdRcd>().get(thresholdHandle);
240  iSetup.get<SiStripPedestalsRcd>().get(pedestalHandle);
241 
242  std::unique_ptr<bool> simulateAPVInThisEvent = std::make_unique<bool>(false);
243  if (includeAPVSimulation_) {
244  if (CLHEP::RandFlat::shoot(randomEngine_) < fracOfEventsToSimAPV_ ) {
245  *simulateAPVInThisEvent = true;
246  iSetup.get<SiStripApvSimulationParametersRcd>().get(apvSimulationParametersHandle);
247  }
248  }
249  std::vector<edm::DetSet<SiStripDigi>> theDigiVector;
250  std::vector<edm::DetSet<SiStripRawDigi>> theRawDigiVector;
251  std::unique_ptr<edm::DetSetVector<SiStripRawDigi>> theStripAmplitudeVector( new edm::DetSetVector<SiStripRawDigi>());
252  std::unique_ptr<edm::DetSetVector<SiStripRawDigi>> theStripAmplitudeVectorPostAPV( new edm::DetSetVector<SiStripRawDigi>());
253  std::unique_ptr<edm::DetSetVector<SiStripRawDigi>> theStripAPVBaselines( new edm::DetSetVector<SiStripRawDigi>());
254  std::unique_ptr<edm::DetSetVector<StripDigiSimLink>> pOutputDigiSimLink(new edm::DetSetVector<StripDigiSimLink>);
255 
257  iSetup.get<TrackerTopologyRcd>().get(tTopoHand);
258  const TrackerTopology* tTopo = tTopoHand.product();
259 
260  // Step B: LOOP on StripGeomDetUnit
261  theDigiVector.reserve(10000);
262  theDigiVector.clear();
263 
264  for (const auto& iu : pDD->detUnits()) {
265  if (useConfFromDB) {
266  //apply the cable map _before_ digitization: consider only the detis that are connected
267  if (theDetIdList.find(iu->geographicalId().rawId()) == theDetIdList.end())
268  continue;
269  }
270  auto sgd = dynamic_cast<StripGeomDetUnit const*>(iu);
271  if (sgd != nullptr) {
272  edm::DetSet<SiStripDigi> collectorZS(iu->geographicalId().rawId());
273  edm::DetSet<SiStripRawDigi> collectorRaw(iu->geographicalId().rawId());
274  edm::DetSet<SiStripRawDigi> collectorStripAmplitudes(iu->geographicalId().rawId());
275  edm::DetSet<SiStripRawDigi> collectorStripAmplitudesPostAPV(iu->geographicalId().rawId());
276  edm::DetSet<SiStripRawDigi> collectorStripAPVBaselines(iu->geographicalId().rawId());
277  edm::DetSet<StripDigiSimLink> collectorLink(iu->geographicalId().rawId());
278 
279  unsigned int detID = sgd->geographicalId().rawId();
280  DetId detId(detID);
281 
282  theDigiAlgo->digitize(collectorZS,
283  collectorRaw,
284  collectorStripAmplitudes,
285  collectorStripAmplitudesPostAPV,
286  collectorStripAPVBaselines,
287  collectorLink,
288  sgd,
289  gainHandle,
290  thresholdHandle,
291  noiseHandle,
292  pedestalHandle,
293  *simulateAPVInThisEvent,
294  apvSimulationParametersHandle,
297  tTopo);
298 
299  if ( !collectorStripAmplitudes.data.empty() ) theStripAmplitudeVector->insert(collectorStripAmplitudes);
300  if ( !collectorStripAmplitudesPostAPV.data.empty() ) theStripAmplitudeVectorPostAPV->insert(collectorStripAmplitudesPostAPV);
301  if ( !collectorStripAPVBaselines.data.empty() ) theStripAPVBaselines->insert(collectorStripAPVBaselines);
302 
303  if (zeroSuppression) {
304  if (!collectorZS.data.empty()) {
305  theDigiVector.push_back(collectorZS);
306  if (!collectorLink.data.empty())
307  pOutputDigiSimLink->insert(collectorLink);
308  }
309  } else {
310  if (!collectorRaw.data.empty()) {
311  theRawDigiVector.push_back(collectorRaw);
312  if (!collectorLink.data.empty())
313  pOutputDigiSimLink->insert(collectorLink);
314  }
315  }
316  }
317  }
318  if (zeroSuppression) {
319  // Step C: create output collection
320  std::unique_ptr<edm::DetSetVector<SiStripRawDigi>> output_virginraw(new edm::DetSetVector<SiStripRawDigi>());
321  std::unique_ptr<edm::DetSetVector<SiStripRawDigi>> output_scopemode(new edm::DetSetVector<SiStripRawDigi>());
322  std::unique_ptr<edm::DetSetVector<SiStripRawDigi>> output_processedraw(new edm::DetSetVector<SiStripRawDigi>());
323  std::unique_ptr<edm::DetSetVector<SiStripDigi>> output(new edm::DetSetVector<SiStripDigi>(theDigiVector));
324  std::unique_ptr<std::vector<std::pair<int, std::bitset<6>>>> AffectedAPVList(
325  new std::vector<std::pair<int, std::bitset<6>>>(theAffectedAPVvector));
326 
327  // Step D: write output to file
328  iEvent.put(std::move(output), ZSDigi);
329  iEvent.put(std::move(output_scopemode), SCDigi);
330  iEvent.put(std::move(output_virginraw), VRDigi);
331  iEvent.put(std::move(theStripAmplitudeVector), "StripAmplitudes");
332  iEvent.put(std::move(theStripAmplitudeVectorPostAPV), "StripAmplitudesPostAPV");
333  iEvent.put(std::move(theStripAPVBaselines), "StripAPVBaselines");
334  iEvent.put(std::move(output_processedraw), PRDigi);
335  iEvent.put(std::move(AffectedAPVList), "AffectedAPVList");
336  iEvent.put(std::move(simulateAPVInThisEvent), "SimulatedAPVDynamicGain");
337  if (makeDigiSimLinks_)
338  iEvent.put(
339  std::move(pOutputDigiSimLink)); // The previous EDProducer didn't name this collection so I won't either
340  } else {
341  // Step C: create output collection
342  std::unique_ptr<edm::DetSetVector<SiStripRawDigi>> output_virginraw(
343  new edm::DetSetVector<SiStripRawDigi>(theRawDigiVector));
344  std::unique_ptr<edm::DetSetVector<SiStripRawDigi>> output_scopemode(new edm::DetSetVector<SiStripRawDigi>());
345  std::unique_ptr<edm::DetSetVector<SiStripRawDigi>> output_processedraw(new edm::DetSetVector<SiStripRawDigi>());
346  std::unique_ptr<edm::DetSetVector<SiStripDigi>> output(new edm::DetSetVector<SiStripDigi>());
347 
348  // Step D: write output to file
349  iEvent.put(std::move(output), ZSDigi);
350  iEvent.put(std::move(output_scopemode), SCDigi);
351  iEvent.put(std::move(output_virginraw), VRDigi);
352  iEvent.put(std::move(theStripAmplitudeVector), "StripAmplitudes");
353  iEvent.put(std::move(theStripAmplitudeVectorPostAPV), "StripAmplitudesPostAPV");
354  iEvent.put(std::move(theStripAPVBaselines), "StripAPVBaselines");
355  iEvent.put(std::move(output_processedraw), PRDigi);
356  iEvent.put(std::move(simulateAPVInThisEvent), "SimulatedAPVDynamicGain");
357  if (makeDigiSimLinks_)
358  iEvent.put(
359  std::move(pOutputDigiSimLink)); // The previous EDProducer didn't name this collection so I won't either
360  }
361  randomEngine_ = nullptr; // to prevent access outside event
362 }
const std::string ZSDigi
edm::ESHandle< TrackerGeometry > pDD
const DetContainer & detUnits() const override
Returm a vector of all GeomDet.
const bool zeroSuppression
const bool useConfFromDB
std::map< uint32_t, std::vector< int > > theDetIdList
CLHEP::HepRandomEngine * randomEngine_
int iEvent
Definition: GenABIO.cc:224
const bool includeAPVSimulation_
Definition: DetId.h:18
std::unique_ptr< SiStripDigitizerAlgorithm > theDigiAlgo
const std::string VRDigi
const std::string PRDigi
std::vector< std::pair< int, std::bitset< 6 > > > theAffectedAPVvector
const double fracOfEventsToSimAPV_
Whether or not to create the association to sim truth collection. Set in configuration.
const bool makeDigiSimLinks_
T const * product() const
Definition: ESHandle.h:86
const std::string gainLabel
def move(src, dest)
Definition: eostools.py:511
const std::string SCDigi
PileupMixingContent* SiStripDigitizer::getEventPileupInfo ( )
inlineoverridevirtual

Reimplemented from DigiAccumulatorMixMod.

Definition at line 65 of file SiStripDigitizer.h.

65 { return PileupInfo_.get(); }
std::unique_ptr< PileupMixingContent > PileupInfo_
void SiStripDigitizer::initializeEvent ( edm::Event const &  e,
edm::EventSetup const &  c 
)
overridevirtual

Implements DigiAccumulatorMixMod.

Definition at line 189 of file SiStripDigitizer.cc.

References SiStripDetCabling::addConnected(), crossingSimHitIndexOffset_, detectorUnits, TrackerGeometry::detUnits(), geometryType, edm::EventSetup::get(), edm::RandomNumberGenerator::getEngine(), pDD, pSetup, randomEngine_, edm::Event::streamID(), theAffectedAPVvector, theDetIdList, theDigiAlgo, and useConfFromDB.

189  {
190  // Make sure that the first crossing processed starts indexing the sim hits from zero.
191  // This variable is used so that the sim hits from all crossing frames have sequential
192  // indices used to create the digi-sim link (if configured to do so) rather than starting
193  // from zero for each crossing.
195  theAffectedAPVvector.clear();
196  // Step A: Get Inputs
197 
198  if (useConfFromDB) {
200  iSetup.get<SiStripDetCablingRcd>().get(detCabling);
201  detCabling->addConnected(theDetIdList);
202  }
203 
204  // Cache random number engine
206  randomEngine_ = &rng->getEngine(iEvent.streamID());
207 
208  theDigiAlgo->initializeEvent(iSetup);
209 
210  iSetup.get<TrackerDigiGeometryRecord>().get(geometryType, pDD);
211  iSetup.get<IdealMagneticFieldRecord>().get(pSetup);
212 
213  // FIX THIS! We only need to clear and (re)fill detectorUnits when the geometry type IOV changes. Use ESWatcher to determine this.
214  bool changes = true;
215  if (changes) { // Replace with ESWatcher
216  detectorUnits.clear();
217  }
218  for (const auto& iu : pDD->detUnits()) {
219  unsigned int detId = iu->geographicalId().rawId();
220  if (iu->type().isTrackerStrip()) {
221  auto stripdet = dynamic_cast<StripGeomDetUnit const*>(iu);
222  assert(stripdet != nullptr);
223  if (changes) { // Replace with ESWatcher
224  detectorUnits.insert(std::make_pair(detId, stripdet));
225  }
226  theDigiAlgo->initializeDetUnit(stripdet, iSetup);
227  }
228  }
229 }
edm::ESHandle< TrackerGeometry > pDD
const DetContainer & detUnits() const override
Returm a vector of all GeomDet.
std::map< unsigned int, StripGeomDetUnit const * > detectorUnits
virtual CLHEP::HepRandomEngine & getEngine(StreamID const &)=0
Use this engine in event methods.
const bool useConfFromDB
std::map< uint32_t, std::vector< int > > theDetIdList
CLHEP::HepRandomEngine * randomEngine_
int iEvent
Definition: GenABIO.cc:224
std::unique_ptr< SiStripDigitizerAlgorithm > theDigiAlgo
edm::ESHandle< MagneticField > pSetup
const std::string geometryType
std::vector< std::pair< int, std::bitset< 6 > > > theAffectedAPVvector
std::map< std::string, size_t > crossingSimHitIndexOffset_
Offset to add to the index of each sim hit to account for which crossing it&#39;s in. ...
void addConnected(std::map< uint32_t, std::vector< int >> &) const
void SiStripDigitizer::StorePileupInformation ( std::vector< int > &  numInteractionList,
std::vector< int > &  bunchCrossingList,
std::vector< float > &  TrueInteractionList,
std::vector< edm::EventID > &  eventInfoList,
int  bunchSpacing 
)
inlineoverridevirtual

Reimplemented from DigiAccumulatorMixMod.

Definition at line 56 of file SiStripDigitizer.h.

References genPUProtons_cfi::bunchCrossingList.

60  {
61  PileupInfo_ = std::make_unique<PileupMixingContent>(
62  numInteractionList, bunchCrossingList, TrueInteractionList, eventInfoList, bunchSpacing);
63  }
std::unique_ptr< PileupMixingContent > PileupInfo_

Member Data Documentation

std::map<std::string, size_t> SiStripDigitizer::crossingSimHitIndexOffset_
private

Offset to add to the index of each sim hit to account for which crossing it's in.

I need to know what each sim hit index will be when the hits from all crossing frames are merged into one collection (assuming the MixingModule is configured to create the crossing frame for all sim hits). To do this I'll record how many hits were in each crossing, and then add that on to the index for a given hit in a given crossing. This assumes that the crossings are processed in the same order here as they are put into the crossing frame, which I'm pretty sure is true.
The key is the name of the sim hit collection.

Definition at line 100 of file SiStripDigitizer.h.

Referenced by accumulate(), and initializeEvent().

std::map<unsigned int, StripGeomDetUnit const*> SiStripDigitizer::detectorUnits
private

Definition at line 106 of file SiStripDigitizer.h.

Referenced by accumulateStripHits(), and initializeEvent().

const double SiStripDigitizer::fracOfEventsToSimAPV_
private

Whether or not to create the association to sim truth collection. Set in configuration.

Definition at line 89 of file SiStripDigitizer.h.

Referenced by finalizeEvent().

const std::string SiStripDigitizer::gainLabel
private

Definition at line 77 of file SiStripDigitizer.h.

Referenced by finalizeEvent().

const std::string SiStripDigitizer::geometryType
private

Definition at line 84 of file SiStripDigitizer.h.

Referenced by initializeEvent().

const std::string SiStripDigitizer::hitsProducer
private

Definition at line 78 of file SiStripDigitizer.h.

Referenced by accumulate(), and SiStripDigitizer().

const bool SiStripDigitizer::includeAPVSimulation_
private

Definition at line 88 of file SiStripDigitizer.h.

Referenced by finalizeEvent().

const bool SiStripDigitizer::makeDigiSimLinks_
private

Definition at line 87 of file SiStripDigitizer.h.

Referenced by finalizeEvent().

edm::ESHandle<TrackerGeometry> SiStripDigitizer::pDD
private

Definition at line 104 of file SiStripDigitizer.h.

Referenced by finalizeEvent(), and initializeEvent().

std::unique_ptr<PileupMixingContent> SiStripDigitizer::PileupInfo_
private

Definition at line 110 of file SiStripDigitizer.h.

Referenced by accumulate().

const std::string SiStripDigitizer::PRDigi
private

Definition at line 83 of file SiStripDigitizer.h.

Referenced by finalizeEvent(), and SiStripDigitizer().

edm::ESHandle<MagneticField> SiStripDigitizer::pSetup
private

Definition at line 105 of file SiStripDigitizer.h.

Referenced by accumulateStripHits(), and initializeEvent().

CLHEP::HepRandomEngine* SiStripDigitizer::randomEngine_ = nullptr
private

Definition at line 107 of file SiStripDigitizer.h.

Referenced by accumulateStripHits(), finalizeEvent(), and initializeEvent().

const std::string SiStripDigitizer::SCDigi
private

Definition at line 81 of file SiStripDigitizer.h.

Referenced by finalizeEvent(), and SiStripDigitizer().

std::vector<std::pair<int, std::bitset<6> > > SiStripDigitizer::theAffectedAPVvector
private

Definition at line 108 of file SiStripDigitizer.h.

Referenced by finalizeEvent(), and initializeEvent().

std::map<uint32_t, std::vector<int> > SiStripDigitizer::theDetIdList
private

Definition at line 103 of file SiStripDigitizer.h.

Referenced by finalizeEvent(), and initializeEvent().

std::unique_ptr<SiStripDigitizerAlgorithm> SiStripDigitizer::theDigiAlgo
private
const vstring SiStripDigitizer::trackerContainers
private

Definition at line 79 of file SiStripDigitizer.h.

Referenced by accumulate(), and SiStripDigitizer().

const bool SiStripDigitizer::useConfFromDB
private

Definition at line 85 of file SiStripDigitizer.h.

Referenced by finalizeEvent(), and initializeEvent().

const std::string SiStripDigitizer::VRDigi
private

Definition at line 82 of file SiStripDigitizer.h.

Referenced by finalizeEvent(), and SiStripDigitizer().

const bool SiStripDigitizer::zeroSuppression
private

Definition at line 86 of file SiStripDigitizer.h.

Referenced by finalizeEvent().

const std::string SiStripDigitizer::ZSDigi
private

Definition at line 80 of file SiStripDigitizer.h.

Referenced by finalizeEvent(), and SiStripDigitizer().