CMS 3D CMS Logo

List of all members | Public Member Functions | Private Attributes
muonAssociatorByHitsDiagnostics::InputDumper Class Reference

Public Member Functions

void dump (const TrackHitsCollection &, const TrackingParticleCollection &, const edm::Event &) const
 
 InputDumper (const edm::ParameterSet &conf)
 
 InputDumper (const edm::ParameterSet &conf, edm::ConsumesCollector &&iC)
 

Private Attributes

const bool crossingframe
 
const edm::InputTag simtracksTag
 
const edm::InputTag simtracksXFTag
 

Detailed Description

Definition at line 23 of file MuonAssociatorByHits.cc.

Constructor & Destructor Documentation

◆ InputDumper() [1/2]

muonAssociatorByHitsDiagnostics::InputDumper::InputDumper ( const edm::ParameterSet conf)
inline

Definition at line 25 of file MuonAssociatorByHits.cc.

26  : simtracksTag(conf.getParameter<edm::InputTag>("simtracksTag")),
27  simtracksXFTag(conf.getParameter<edm::InputTag>("simtracksXFTag")),
28  crossingframe(conf.getParameter<bool>("crossingframe")) {}

◆ InputDumper() [2/2]

muonAssociatorByHitsDiagnostics::InputDumper::InputDumper ( const edm::ParameterSet conf,
edm::ConsumesCollector &&  iC 
)
inline

Member Function Documentation

◆ dump()

void muonAssociatorByHitsDiagnostics::InputDumper::dump ( const TrackHitsCollection tC,
const TrackingParticleCollection tPC,
const edm::Event event 
) const

Definition at line 48 of file MuonAssociatorByHits.cc.

50  {
51  // reco::Track collection
52  edm::LogVerbatim("MuonAssociatorByHits") << "\n"
53  << "reco::Track collection --- size = " << tC.size();
54 
55  // TrackingParticle collection
56  edm::LogVerbatim("MuonAssociatorByHits") << "\n"
57  << "TrackingParticle collection --- size = " << tPC.size();
58  int j = 0;
59  for (TrackingParticleCollection::const_iterator ITER = tPC.begin(); ITER != tPC.end(); ITER++, j++) {
60  edm::LogVerbatim("MuonAssociatorByHits")
61  << "TrackingParticle " << j << ", q = " << ITER->charge() << ", p = " << ITER->p() << ", pT = " << ITER->pt()
62  << ", eta = " << ITER->eta() << ", phi = " << ITER->phi();
63 
64  edm::LogVerbatim("MuonAssociatorByHits")
65  << "\t pdg code = " << ITER->pdgId() << ", made of " << ITER->numberOfHits() << " PSimHit"
66  << " (in " << ITER->numberOfTrackerLayers() << " layers)"
67  << " from " << ITER->g4Tracks().size() << " SimTrack:";
68  for (TrackingParticle::g4t_iterator g4T = ITER->g4Track_begin(); g4T != ITER->g4Track_end(); g4T++) {
69  edm::LogVerbatim("MuonAssociatorByHits") << "\t\t Id:" << g4T->trackId() << "/Evt:(" << g4T->eventId().event()
70  << "," << g4T->eventId().bunchCrossing() << ")";
71  }
72  }
73 
74  // SimTrack collection
77 
78  // SimVertex collection
81 
82  if (crossingframe) {
83  event.getByLabel(simtracksXFTag, cf_simtracks);
84  unique_ptr<MixCollection<SimTrack>> SimTk(new MixCollection<SimTrack>(cf_simtracks.product()));
85  edm::LogVerbatim("MuonAssociatorByHits")
86  << "\n"
87  << "CrossingFrame<SimTrack> collection with InputTag = " << simtracksXFTag << " has size = " << SimTk->size();
88  int k = 0;
89  for (MixCollection<SimTrack>::MixItr ITER = SimTk->begin(); ITER != SimTk->end(); ITER++, k++) {
90  edm::LogVerbatim("MuonAssociatorByHits")
91  << "SimTrack " << k << " - Id:" << ITER->trackId() << "/Evt:(" << ITER->eventId().event() << ","
92  << ITER->eventId().bunchCrossing() << ")"
93  << " pdgId = " << ITER->type() << ", q = " << ITER->charge() << ", p = " << ITER->momentum().P()
94  << ", pT = " << ITER->momentum().Pt() << ", eta = " << ITER->momentum().Eta()
95  << ", phi = " << ITER->momentum().Phi() << "\n * " << *ITER << endl;
96  }
97  event.getByLabel(simtracksXFTag, cf_simvertices);
98  unique_ptr<MixCollection<SimVertex>> SimVtx(new MixCollection<SimVertex>(cf_simvertices.product()));
99  edm::LogVerbatim("MuonAssociatorByHits")
100  << "\n"
101  << "CrossingFrame<SimVertex> collection with InputTag = " << simtracksXFTag
102  << " has size = " << SimVtx->size();
103  int kv = 0;
104  for (MixCollection<SimVertex>::MixItr VITER = SimVtx->begin(); VITER != SimVtx->end(); VITER++, kv++) {
105  edm::LogVerbatim("MuonAssociatorByHits") << "SimVertex " << kv << " : " << *VITER << endl;
106  }
107  } else {
108  event.getByLabel(simtracksTag, simTrackCollection);
109  const edm::SimTrackContainer simTC = *(simTrackCollection.product());
110  edm::LogVerbatim("MuonAssociatorByHits")
111  << "\n"
112  << "SimTrack collection with InputTag = " << simtracksTag << " has size = " << simTC.size() << endl;
113  int k = 0;
114  for (edm::SimTrackContainer::const_iterator ITER = simTC.begin(); ITER != simTC.end(); ITER++, k++) {
115  edm::LogVerbatim("MuonAssociatorByHits")
116  << "SimTrack " << k << " - Id:" << ITER->trackId() << "/Evt:(" << ITER->eventId().event() << ","
117  << ITER->eventId().bunchCrossing() << ")"
118  << " pdgId = " << ITER->type() << ", q = " << ITER->charge() << ", p = " << ITER->momentum().P()
119  << ", pT = " << ITER->momentum().Pt() << ", eta = " << ITER->momentum().Eta()
120  << ", phi = " << ITER->momentum().Phi() << "\n * " << *ITER << endl;
121  }
122  event.getByLabel(simtracksTag, simVertexCollection);
123  const edm::SimVertexContainer simVC = *(simVertexCollection.product());
124  edm::LogVerbatim("MuonAssociatorByHits") << "\n"
125  << "SimVertex collection with InputTag = "
126  << "g4SimHits"
127  << " has size = " << simVC.size() << endl;
128  int kv = 0;
129  for (edm::SimVertexContainer::const_iterator VITER = simVC.begin(); VITER != simVC.end(); VITER++, kv++) {
130  edm::LogVerbatim("MuonAssociatorByHits") << "SimVertex " << kv << " : " << *VITER << endl;
131  }
132  }
133  }

References MuonAssociatorByHits_cfi::crossingframe, dqmiolumiharvest::j, dqmdumpme::k, edm::Handle< T >::product(), caloTruthProducer_cfi::simTrackCollection, MuonAssociatorByHits_cfi::simtracksTag, MuonAssociatorByHits_cfi::simtracksXFTag, and caloTruthProducer_cfi::simVertexCollection.

Member Data Documentation

◆ crossingframe

const bool muonAssociatorByHitsDiagnostics::InputDumper::crossingframe
private

Definition at line 45 of file MuonAssociatorByHits.cc.

◆ simtracksTag

const edm::InputTag muonAssociatorByHitsDiagnostics::InputDumper::simtracksTag
private

Definition at line 43 of file MuonAssociatorByHits.cc.

◆ simtracksXFTag

const edm::InputTag muonAssociatorByHitsDiagnostics::InputDumper::simtracksXFTag
private

Definition at line 44 of file MuonAssociatorByHits.cc.

edm::Handle::product
T const * product() const
Definition: Handle.h:70
TrackingParticle::g4t_iterator
std::vector< SimTrack >::const_iterator g4t_iterator
Definition: TrackingParticle.h:41
caloTruthProducer_cfi.simVertexCollection
simVertexCollection
Definition: caloTruthProducer_cfi.py:29
edm::Handle
Definition: AssociativeIterator.h:50
MixCollection::MixItr
Definition: MixCollection.h:62
muonAssociatorByHitsDiagnostics::InputDumper::simtracksXFTag
const edm::InputTag simtracksXFTag
Definition: MuonAssociatorByHits.cc:44
caloTruthProducer_cfi.simTrackCollection
simTrackCollection
Definition: caloTruthProducer_cfi.py:28
CrossingFrame
Definition: CrossingFrame.h:38
MixCollection
Definition: MixCollection.h:11
edm::ConsumesCollector::consumes
EDGetTokenT< ProductType > consumes(edm::InputTag const &tag)
Definition: ConsumesCollector.h:49
dqmdumpme.k
k
Definition: dqmdumpme.py:60
muonAssociatorByHitsDiagnostics::InputDumper::InputDumper
InputDumper(const edm::ParameterSet &conf)
Definition: MuonAssociatorByHits.cc:25
edm::LogVerbatim
Definition: MessageLogger.h:297
muonAssociatorByHitsDiagnostics::InputDumper::crossingframe
const bool crossingframe
Definition: MuonAssociatorByHits.cc:45
edm::ParameterSet::getParameter
T getParameter(std::string const &) const
edm::SimTrackContainer
std::vector< SimTrack > SimTrackContainer
Definition: SimTrackContainer.h:12
dqmiolumiharvest.j
j
Definition: dqmiolumiharvest.py:66
edm::SimVertexContainer
std::vector< SimVertex > SimVertexContainer
Definition: SimVertexContainer.h:12
edm::InputTag
Definition: InputTag.h:15
muonAssociatorByHitsDiagnostics::InputDumper::simtracksTag
const edm::InputTag simtracksTag
Definition: MuonAssociatorByHits.cc:43