31 m_evt = findNode::getClass<SQEvent>(topNode,
"SQEvent");
32 m_mcevt = findNode::getClass<SQMCEvent>(topNode,
"SQMCEvent");
33 m_vec_trk = findNode::getClass<SQTrackVector>(topNode,
"SQTruthTrackVector");
34 m_vec_dim = findNode::getClass<SQDimuonVector>(topNode,
"SQTruthDimuonVector");
35 m_g4true = findNode::getClass<PHG4TruthInfoContainer>(topNode,
"G4TruthInfo");
41 static unsigned int n_evt = 0;
42 cout <<
"TracePHG4: Event " << ++n_evt <<
"\n";
47 for (
int ii = 0; ii < 4; ii++) {
60 for (
unsigned int ii = 0; ii < m_vec_trk->
size(); ii++) {
69 for (
unsigned int ii = 0; ii < m_vec_dim->
size(); ii++) {
87 void TracePHG4Particle::PrintPrimaryParticles()
89 cout <<
" PHG4P Primary:";
98 void TracePHG4Particle::PrintParticles()
100 cout <<
" PHG4P All:";
110 void TracePHG4Particle::PrintTraces(
const int pdg_id)
114 if (par->
get_pid() == pdg_id) TraceParent(par);
118 void TracePHG4Particle::TraceParent(
const PHG4Particle* par,
const int depth)
120 if (depth == 1) cout <<
" Trace ";
136 TraceParent(par, depth + 1);
140 cout <<
"[Unexpected Case]" << endl;
virtual int get_track_id() const
virtual int get_pid() const
virtual int get_parent_id() const
Range GetParticleRange()
Get a range of iterators covering the entire container.
Range GetPrimaryParticleRange()
virtual const SQDimuon * at(const size_t id) const =0
virtual size_t size() const =0
An SQ interface class to hold one true or reconstructed dimuon.
virtual int get_pdg_id() const =0
Return the GPD ID of parent particle. It is valid only for true dimuon.
virtual int get_particle_id(const int i) const =0
Return the particle ID of the primary process, where i=0...3 for "0 + 1 -> 2 + 3".
virtual double get_weight() const =0
Return the event weight.
virtual int get_process_id() const =0
Return the primary process ID.
virtual const SQTrack * at(const size_t id) const =0
virtual size_t size() const =0
An SQ interface class to hold one true or reconstructed track.
virtual int get_charge() const =0
Return the charge, i.e. +1 or -1.
int process_event(PHCompositeNode *topNode)
int Init(PHCompositeNode *topNode)
int InitRun(PHCompositeNode *topNode)
int End(PHCompositeNode *topNode)
Called at the end of all processing.