CMS 3D CMS Logo

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

#include <PSimHitMap.h>

Public Member Functions

std::vector< int > detsWithHits () const
 
void fill (const edm::Event &e)
 
const edm::PSimHitContainerhits (int detId) const
 
 PSimHitMap (const edm::InputTag &iT, edm::ConsumesCollector &&iC)
 

Private Attributes

edm::EDGetTokenT< CrossingFrame< PSimHit > > sh_token
 
edm::PSimHitContainer theEmptyContainer
 
std::map< int, edm::PSimHitContainertheMap
 

Detailed Description

Definition at line 11 of file PSimHitMap.h.

Constructor & Destructor Documentation

PSimHitMap::PSimHitMap ( const edm::InputTag iT,
edm::ConsumesCollector &&  iC 
)
inline

Definition at line 13 of file PSimHitMap.h.

References detsWithHits(), MillePedeFileConverter_cfg::e, fill(), hits(), and sh_token.

13  : theMap(), theEmptyContainer() {
15  }
EDGetTokenT< ProductType > consumes(edm::InputTag const &tag)
edm::PSimHitContainer theEmptyContainer
Definition: PSimHitMap.h:25
edm::EDGetTokenT< CrossingFrame< PSimHit > > sh_token
Definition: PSimHitMap.h:27
std::map< int, edm::PSimHitContainer > theMap
Definition: PSimHitMap.h:24

Member Function Documentation

std::vector< int > PSimHitMap::detsWithHits ( ) const

Definition at line 28 of file PSimHitMap.cc.

References mps_fire::result, and theMap.

Referenced by CSCRecHit2DValidation::analyze(), CSCSegmentValidation::fillLayerHitsPerChamber(), and PSimHitMap().

28  {
29  std::vector<int> result;
30  result.reserve(theMap.size());
31  for (std::map<int, edm::PSimHitContainer>::const_iterator mapItr = theMap.begin(), mapEnd = theMap.end();
32  mapItr != mapEnd;
33  ++mapItr) {
34  result.push_back(mapItr->first);
35  }
36  return result;
37 }
std::map< int, edm::PSimHitContainer > theMap
Definition: PSimHitMap.h:24
void PSimHitMap::fill ( const edm::Event e)

Definition at line 4 of file PSimHitMap.cc.

References edm::Event::getByToken(), LogTrace, edm::Handle< T >::product(), sh_token, trackerHits::simHits, and theMap.

Referenced by CSCRecHitValidation::analyze(), CSCDigiValidation::analyze(), and PSimHitMap().

4  {
5  theMap.clear();
7  LogTrace("PSimHitMap") << "getting CrossingFrame<PSimHit> collection ";
8  e.getByToken(sh_token, cf);
9 
11  LogTrace("PSimHitMap") << "... size = " << simHits.size();
12 
13  // arrange the hits by detUnit
14  for (MixCollection<PSimHit>::MixItr hitItr = simHits.begin(); hitItr != simHits.end(); ++hitItr) {
15  theMap[hitItr->detUnitId()].push_back(*hitItr);
16  }
17 }
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:517
edm::EDGetTokenT< CrossingFrame< PSimHit > > sh_token
Definition: PSimHitMap.h:27
#define LogTrace(id)
std::map< int, edm::PSimHitContainer > theMap
Definition: PSimHitMap.h:24
T const * product() const
Definition: Handle.h:74
const edm::PSimHitContainer & PSimHitMap::hits ( int  detId) const

Definition at line 19 of file PSimHitMap.cc.

References theEmptyContainer, and theMap.

Referenced by CSCRecHit2DValidation::analyze(), CSCWireDigiValidation::analyze(), CSCSegmentValidation::fillLayerHitsPerChamber(), CSCSegmentValidation::keyHit(), and PSimHitMap().

19  {
20  std::map<int, edm::PSimHitContainer>::const_iterator mapItr = theMap.find(detId);
21  if (mapItr != theMap.end()) {
22  return mapItr->second;
23  } else {
24  return theEmptyContainer;
25  }
26 }
edm::PSimHitContainer theEmptyContainer
Definition: PSimHitMap.h:25
std::map< int, edm::PSimHitContainer > theMap
Definition: PSimHitMap.h:24

Member Data Documentation

edm::EDGetTokenT<CrossingFrame<PSimHit> > PSimHitMap::sh_token
private

Definition at line 27 of file PSimHitMap.h.

Referenced by fill(), and PSimHitMap().

edm::PSimHitContainer PSimHitMap::theEmptyContainer
private

Definition at line 25 of file PSimHitMap.h.

Referenced by hits().

std::map<int, edm::PSimHitContainer> PSimHitMap::theMap
private

Definition at line 24 of file PSimHitMap.h.

Referenced by detsWithHits(), fill(), and hits().