27 #include <TClonesArray.h>
30 #include <boost/foreach.hpp>
47 SubsysReco(
"PHG4DSTReader"), nblocks(0), _event(0),
48 _out_file_name(filename), _T(nullptr),
49 _save_particle(true), _load_all_particle(false), _load_active_particle(
50 true), _save_vertex(true)
58 cout <<
"PHG4DSTReader::destructor - Clean ups" << endl;
62 _T->ResetBranchAddresses();
72 const int arr_size = 100;
75 for (vector<string>::const_iterator it =
_node_postfix.begin();
78 const char * class_name = hit_type::Class()->GetName();
80 const string & nodenam = *it;
82 string hname =
"G4HIT_" + nodenam;
84 cout <<
"PHG4DSTReader::Init - saving hits from node: " << hname <<
" - "
85 << class_name << endl;
90 rec.
_arr = std::make_shared<TClonesArray>(class_name, arr_size);
103 const char * class_name = part_type::Class()->GetName();
105 cout <<
"PHG4DSTReader::Init - saving Particles node:" << class_name
110 rec.
_name =
"PHG4Particle";
111 rec.
_arr = std::make_shared<TClonesArray>(class_name, arr_size);
124 const char * class_name = vertex_type::Class()->GetName();
126 cout <<
"PHG4DSTReader::Init - saving vertex for particles under node:"
127 << class_name << endl;
131 rec.
_name =
"PHG4VtxPoint";
132 rec.
_arr = std::make_shared<TClonesArray>(class_name, arr_size);
141 cout <<
"PHG4DSTReader::Init - requested " <<
nblocks <<
" nodes" << endl;
151 cout <<
"PHG4DSTReader::build_tree - output to " <<
_out_file_name << endl;
153 static const int BUFFER_SIZE = 32000;
158 _T =
new TTree(
"T",
"PHG4DSTReader");
165 cout <<
"PHG4DSTReader::build_tree - Add " << rec.
_name << endl;
167 const string name_cnt =
"n_" + rec.
_name;
168 const string name_cnt_desc = name_cnt +
"/I";
169 _T->Branch(name_cnt.c_str(), &(rec.
_cnt), name_cnt_desc.c_str(),
176 cout <<
"PHG4DSTReader::build_tree - added " <<
nblocks <<
" nodes" << endl;
178 _T->SetAutoSave(16000);
201 <<
"PHG4DSTReader::process_event - Error - can not find node G4TruthInfo. Quit processing!"
212 assert(rec.
_arr.get());
218 cout <<
"PHG4DSTReader::process_event - processing " << rec.
_name
227 <<
"PHG4DSTReader::process_event - Error - can not find node "
228 << rec.
_name << endl;
236 cout <<
"PHG4DSTReader::process_event - processing "
237 << rec.
_name <<
" and received " << hits->
size() <<
" hits"
241 hit_iter != hit_range.second; hit_iter++)
243 PHG4Hit * hit = hit_iter->second;
273 cout <<
"PHG4DSTReader::process_event - processing "
275 <<
" with track id " << hit->
get_trkid() << endl;
284 map<int, PHG4Particle *>::const_iterator particle_iter;
288 static bool once =
true;
292 <<
"PHG4DSTReader::process_event - will load all particle from G4TruthInfo"
298 for (particle_iter = truthInfoList->
GetMap().begin();
299 particle_iter != truthInfoList->
GetMap().end();
310 static bool once =
true;
314 <<
"PHG4DSTReader::process_event - will load primary particle from G4TruthInfo"
324 primary_range.first; particle_iter != primary_range.second;
335 particle_iter = truthInfoList->
GetMap().find(*i);
336 if (particle_iter == truthInfoList->
GetMap().end())
340 <<
"PHG4DSTReader::process_event - ERROR - can not find particle/track ID "
341 << *i <<
" in G4TruthInfo" << endl;
353 static bool once =
true;
357 <<
"PHG4DSTReader::process_event - will load vertex from G4TruthInfo"
363 for (PartSet_t::const_iterator i =
_vertex_set.begin();
371 <<
"PHG4DSTReader::process_event - ERROR - can not find vertex ID "
372 << *i <<
" in G4TruthInfo" << endl;
380 cout <<
"PHG4DSTReader::process_event - saving vertex id "
445 cout <<
"PHG4DSTReader::End - Clean ups" << endl;
451 _T->ResetBranchAddresses();
PHG4VtxPointv1 vertex_type
virtual int Verbosity() const
Gets the verbosity of this module.
bool _save_vertex
save vertex for particles?
int Init(PHCompositeNode *)
full initialization
bool _load_active_particle
load all particle that produced a saved hit
std::vector< std::string > _node_postfix
void add_particle(record &rec, PHG4Particle *part)
add a particle and associated vertex if _save_vertex
int process_event(PHCompositeNode *)
event processing method
bool _load_all_particle
load all particle in truth info module?
PHG4DSTReader(const std::string &filename)
bool _save_particle
master switch to save particles
int End(PHCompositeNode *)
end of run method
std::string _out_file_name
Map::const_iterator ConstIterator
unsigned int size(void) const
ConstRange getHits(const unsigned int detid) const
return all hits matching a given detid
std::pair< ConstIterator, ConstIterator > ConstRange
PHG4HitEval for evaluating PHG4Hitv1 in CINT readable evaluation trees.
virtual PHG4HitDefs::keytype get_hit_id() const
virtual int get_trkid() const
virtual int get_track_id() const
virtual int get_pid() const
virtual int get_parent_id() const
virtual double get_px() const
virtual int get_primary_id() const
virtual int get_vtx_id() const
virtual std::string get_name() const
virtual double get_py() const
virtual double get_e() const
virtual double get_pz() const
void set_pid(const int i)
void set_pz(const double x)
void set_px(const double x)
void set_name(const std::string &name)
void set_py(const double x)
void set_primary_id(const int i)
void set_parent_id(const int i)
void set_e(const double e)
void set_track_id(const int i)
void set_vtx_id(const int i)
Range GetPrimaryParticleRange()
std::pair< ConstIterator, ConstIterator > ConstRange
PHG4VtxPoint * GetVtx(const int vtxid)
Map::const_iterator ConstIterator
const Map & GetMap() const
Get the Particle Map storage.
virtual double get_y() const
virtual double get_x() const
virtual int get_id() const
virtual double get_z() const
virtual double get_t() const
void set_y(const double r)
void set_t(const double r)
void set_z(const double r)
void set_x(const double r)
static PHTFileServer & get(void)
return reference to class singleton
void open(const std::string &filename, const std::string &type="RECREATE")
open a SafeTFile. If filename is not found in the map, create a new TFile and append to the map; incr...
bool cd(const std::string &filename)
change to directory of TFile matching filename
T * getClass(PHCompositeNode *top, const std::string &name)