19 #include <Geant4/G4ParticleTable.hh>
20 #include <Geant4/G4ParticleDefinition.hh>
21 #include <Geant4/G4SystemOfUnits.hh>
32 steppingAction_(
NULL ),
33 trackingAction_(
NULL ),
34 saveOnlyEmbeded_(false)
49 SQRun* sqrun = findNode::getClass<SQRun>(topNode,
"SQRun");
60 PHG4TruthInfoContainer* truthInfoList = findNode::getClass<PHG4TruthInfoContainer>( topNode ,
"G4TruthInfo" );
91 cout <<
PHWHERE <<
" No EventAction registered" << endl;
95 if ( trackingAction_ )
101 cout <<
PHWHERE <<
" No TrackingAction registered" << endl;
110 if (saveOnlyEmbeded_)
114 cout <<__PRETTY_FUNCTION__<<
" - INFO - only save the G4 truth information that is associated with the embedded particle"<<endl;
117 PHG4TruthInfoContainer* truthInfoList = findNode::getClass<PHG4TruthInfoContainer>( topNode ,
"G4TruthInfo" );
118 assert(truthInfoList);
120 set<int> savevtxlist;
125 while (truthiter != truth_range.second)
127 const int primary_id = (truthiter->second)->get_primary_id();
128 if (truthInfoList->
isEmbeded(primary_id) <= 0)
138 savevtxlist.insert((truthiter->second)->get_vtx_id());
146 while (vtxiter != vtxrange.second)
148 if (savevtxlist.find(vtxiter->first) == savevtxlist.end())
172 {
return eventAction_; }
177 {
return steppingAction_; }
182 return trackingAction_;
virtual int Verbosity() const
Gets the verbosity of this module.
PHBoolean addNode(PHNode *)
virtual int get_IntFlag(const std::string &name) const
int ResetEvent(PHCompositeNode *)
void SetInterfacePointers(PHCompositeNode *)
get relevant nodes from top node passed as argument
VtxRange GetVtxRange()
Get a range of iterators covering the entire vertex container.
Range GetParticleRange()
Get a range of iterators covering the entire container.
std::pair< Iterator, Iterator > Range
int isEmbeded(const int trackid) const
void delete_particle(Iterator piter)
VtxMap::iterator VtxIterator
std::pair< VtxIterator, VtxIterator > VtxRange
void delete_vtx(VtxIterator viter)
int InitRun(PHCompositeNode *)
init
PHG4TruthSubsystem(const std::string &name="TRUTH")
constructor
virtual PHG4EventAction * GetEventAction(void) const
accessors (reimplemented)
int ResetEvent(PHCompositeNode *)
Clean up after each event.
virtual int process_after_geant(PHCompositeNode *)
event processing
virtual PHG4TrackingAction * GetTrackingAction(void) const
return pointer to this subsystem stepping action
int process_event(PHCompositeNode *)
event processing
virtual PHG4SteppingAction * GetSteppingAction(void) const
return pointer to this subsystem stepping action
int ResetEvent(PHCompositeNode *)
virtual void SetInterfacePointers(PHCompositeNode *)
Set pointers to the i/o nodes.
PHNode * findFirst(const std::string &, const std::string &)
An SQ interface class to hold the run-level info.
virtual void set_run_id(const int a)
static recoConsts * instance()