32 g4hc_h1t = findNode::getClass<PHG4HitContainer>(topNode,
"G4HIT_H1T");
33 g4hc_h1b = findNode::getClass<PHG4HitContainer>(topNode,
"G4HIT_H1B");
34 g4hc_h2t = findNode::getClass<PHG4HitContainer>(topNode,
"G4HIT_H2T");
35 g4hc_h2b = findNode::getClass<PHG4HitContainer>(topNode,
"G4HIT_H2B");
36 g4hc_h3t = findNode::getClass<PHG4HitContainer>(topNode,
"G4HIT_H3T");
37 g4hc_h3b = findNode::getClass<PHG4HitContainer>(topNode,
"G4HIT_H3B");
38 g4hc_h4t = findNode::getClass<PHG4HitContainer>(topNode,
"G4HIT_H4T");
39 g4hc_h4b = findNode::getClass<PHG4HitContainer>(topNode,
"G4HIT_H4B");
41 if (!g4hc_h1t || !g4hc_h1b || !g4hc_h2t || !g4hc_h2b ||
42 !g4hc_h3t || !g4hc_h3b || !g4hc_h4t || !g4hc_h4b ) {
51 vector<int> vec_id_h1 = ExtractParticleID(g4hc_h1t, g4hc_h1b);
52 vector<int> vec_id_h2 = ExtractParticleID(g4hc_h2t, g4hc_h2b);
53 vector<int> vec_id_h3 = ExtractParticleID(g4hc_h3t, g4hc_h3b);
54 vector<int> vec_id_h4 = ExtractParticleID(g4hc_h4t, g4hc_h4b);
57 map<int, int> map_nhit;
58 CountHitPlanesPerParticle(vec_id_h1, map_nhit);
59 CountHitPlanesPerParticle(vec_id_h2, map_nhit);
60 CountHitPlanesPerParticle(vec_id_h3, map_nhit);
61 CountHitPlanesPerParticle(vec_id_h4, map_nhit);
65 for (map<int, int>::iterator it = map_nhit.begin(); it != map_nhit.end(); it++) {
66 if (it->second >= m_npl_per_par) n_par_ok++;
77 void SQGeomAccLoose::ExtractParticleID(
const PHG4HitContainer* g4hc, vector<int>& vec_par_id)
89 ExtractParticleID(g4hc_t, vec);
90 ExtractParticleID(g4hc_b, vec);
91 sort(vec.begin(), vec.end());
92 vec.erase(unique(vec.begin(), vec.end()), vec.end());
96 void SQGeomAccLoose::CountHitPlanesPerParticle(
const vector<int> vec_id, map<int, int>& map_nhit)
98 for (vector<int>::const_iterator it = vec_id.begin(); it != vec_id.end(); it++) {
100 if (map_nhit.find(
id) == map_nhit.end()) map_nhit[id] = 1;
Map::const_iterator ConstIterator
ConstRange getHits(const unsigned int detid) const
return all hits matching a given detid
std::pair< ConstIterator, ConstIterator > ConstRange
virtual int get_trkid() const
virtual ~SQGeomAccLoose()
SQGeomAccLoose(const std::string &name="SQGeomAccLoose")
int End(PHCompositeNode *topNode)
Called at the end of all processing.
int InitRun(PHCompositeNode *topNode)
int process_event(PHCompositeNode *topNode)
int Init(PHCompositeNode *topNode)