19 , m_overwrite_rf_info(true)
20 , m_hit_id_shift(10000)
21 , m_trk_id_shift(10000)
22 , m_dim_id_shift(10000)
25 , m_emb_data_has_sim_evt(false)
26 , m_emb_data_has_sim_trk(false)
27 , m_emb_data_has_sim_dim(false)
41 if (m_emb_sqevt )
delete m_emb_sqevt ;
42 if (m_emb_sqmcevt )
delete m_emb_sqmcevt ;
43 if (m_emb_sqvec_hit)
delete m_emb_sqvec_hit;
44 if (m_emb_sqvec_trk)
delete m_emb_sqvec_trk;
45 if (m_emb_sqvec_dim)
delete m_emb_sqvec_dim;
55 mi_evt = findNode::getClass<SQEvent >(topNode,
"SQEvent");
56 mi_vec_hit = findNode::getClass<SQHitVector >(topNode,
"SQHitVector");
57 if (!mi_evt || !mi_vec_hit) {
58 cout <<
PHWHERE <<
": Cannot find SQEvent and/or SQHitVector." << endl;
64 mi_sim_evt = findNode::getClass<SQMCEvent>(topNode,
"SQMCEvent");
69 mi_sim_vec_trk = findNode::getClass<SQTrackVector>(topNode,
"SQTruthTrackVector");
70 if (! mi_sim_vec_trk) {
74 mi_sim_vec_dim = findNode::getClass<SQDimuonVector>(topNode,
"SQTruthDimuonVector");
75 if (! mi_sim_vec_dim) {
79 mi_evt_emb = findNode::getClass<SQEvent>(topNode,
"SQEventEmb");
84 mi_sim_evt_emb = findNode::getClass<SQMCEvent>(topNode,
"SQMCEventEmb");
85 if (! mi_sim_evt_emb) {
102 cout <<
"DoEmbedding::process_event(): Start.\n"
111 *mi_evt_emb = *m_emb_sqevt;
112 if (m_emb_data_has_sim_evt) *mi_sim_evt_emb = *m_emb_sqmcevt;
114 if (m_overwrite_rf_info) {
117 for (
int ii = -16; ii <= 16; ii++) {
122 if (
Verbosity() > 9) cout <<
" N of hits to be embedded: " << m_emb_sqvec_hit->
size() << endl;
124 SQHit* hit_emb = *it;
130 if (m_emb_data_has_sim_trk) {
131 if (
Verbosity() > 9) cout <<
" N of tracks to be embedded: " << m_emb_sqvec_trk->
size() << endl;
139 if (m_emb_data_has_sim_dim) {
140 if (
Verbosity() > 9) cout <<
" N of dimuons to be embedded: " << m_emb_sqvec_dim->
size() << endl;
150 if (
Verbosity() > 9) cout <<
"DoEmbedding::process_event(): End." << endl;
162 m_list_emb_file.push_back(fn_root);
167 ifstream ifs(fn_list);
176 for (vector<string>::iterator it = m_list_emb_file.begin(); it != m_list_emb_file.end(); it++) {
178 num += m_tree_emb->GetEntries();
186 m_file_emb =
new TFile(fn_root);
187 if (! m_file_emb->IsOpen()) {
188 cout <<
"ERROR: Cannot open the embedding-data file, " << fn_root <<
". Abort." << endl;
191 m_tree_emb = (TTree*)m_file_emb->Get(
"tree");
193 cout <<
"ERROR: Cannot get the embedding-data tree. Abort." << endl;
197 cout <<
"DoEmbedding::OpenEmbDataFile(): " << fn_root <<
", N = " << m_tree_emb->GetEntries() <<
"." << endl;
203 if (! m_file_emb)
return;
212 if (m_idx_emb_file >= m_list_emb_file.size())
return false;
213 string fn_root = m_list_emb_file[m_idx_emb_file];
215 m_tree_emb->SetBranchAddress(
"SQEvent" , &m_emb_sqevt );
216 m_tree_emb->SetBranchAddress(
"SQHitVector", &m_emb_sqvec_hit);
217 m_emb_data_has_sim_evt = (m_tree_emb->FindBranch(
"SQMCEvent" ) != 0);
218 m_emb_data_has_sim_trk = (m_tree_emb->FindBranch(
"SQTruthTrackVector" ) != 0);
219 m_emb_data_has_sim_dim = (m_tree_emb->FindBranch(
"SQTruthDimuonVector") != 0);
220 if (m_emb_data_has_sim_evt) m_tree_emb->SetBranchAddress(
"SQMCEvent" , &m_emb_sqmcevt );
221 if (m_emb_data_has_sim_trk) m_tree_emb->SetBranchAddress(
"SQTruthTrackVector" , &m_emb_sqvec_trk);
222 if (m_emb_data_has_sim_dim) m_tree_emb->SetBranchAddress(
"SQTruthDimuonVector", &m_emb_sqvec_dim);
228 if (m_idx_emb_evt >= m_tree_emb->GetEntries()) {
233 m_tree_emb->GetEntry(m_idx_emb_evt++);
int process_event(PHCompositeNode *topNode)
void AddEmbDataFiles(const char *fn_list)
int End(PHCompositeNode *topNode)
Called at the end of all processing.
void OpenEmbDataFile(const char *fn_root)
int Init(PHCompositeNode *topNode)
int InitRun(PHCompositeNode *topNode)
void AddEmbDataFile(const char *fn_root)
DoEmbedding(const std::string name="DoEmbedding")
virtual int Verbosity() const
Gets the verbosity of this module.
PHBoolean addNode(PHNode *)
PHNode * findFirst(const std::string &, const std::string &)
std::vector< SQDimuon * >::iterator Iter
virtual ConstIter begin() const =0
virtual ConstIter end() const =0
virtual size_t size() const =0
virtual void push_back(const SQDimuon *dim)=0
An SQ interface class to hold one true or reconstructed dimuon.
virtual int get_dimuon_id() const =0
Return the dimuon ID, which is unique per event(?).
virtual int get_track_id_neg() const =0
Return the track ID of the negative track.
virtual void set_track_id_neg(const int a)=0
virtual void set_track_id_pos(const int a)=0
virtual int get_track_id_pos() const =0
Return the track ID of the positive track.
virtual void set_dimuon_id(const int a)=0
virtual int get_run_id() const =0
Return the run ID.
virtual void set_qie_turn_id(const int a)=0
virtual int get_qie_rf_intensity(const short i) const =0
Return the i-th QIE RF intensity, where i=-16...+16.
virtual int get_qie_turn_id() const =0
Return the QIE turn ID.
virtual void set_qie_rf_id(const int a)=0
virtual void set_qie_rf_intensity(const short i, const int a)=0
virtual int get_qie_rf_id() const =0
Return the QIE RF ID.
virtual int get_spill_id() const =0
Return the spill ID.
virtual int get_event_id() const =0
Return the event ID, which is unique per run.
virtual ConstIter end() const =0
virtual ConstIter begin() const =0
virtual void push_back(const SQHit *hit)=0
std::vector< SQHit * >::iterator Iter
virtual size_t size() const =0
An SQ interface class to hold one detector hit.
virtual void set_hit_id(const int a)
virtual void set_track_id(const int a)
virtual int get_hit_id() const
Return the ID of this hit.
virtual int get_track_id() const
Return the track ID associated with this hit. Probably the value is not properly set at present.
virtual ConstIter begin() const =0
virtual void push_back(const SQTrack *trk)=0
virtual ConstIter end() const =0
virtual size_t size() const =0
std::vector< SQTrack * >::iterator Iter
An SQ interface class to hold one true or reconstructed track.
virtual int get_track_id() const =0
Return the track ID, which is unique per event(?).
virtual void set_track_id(const int a)=0