6#include "GaudiKernel/MsgStream.h"
7#include "GaudiKernel/SmartDataPtr.h"
32 declareProperty(
"OutputFileName", m_fout=
"histo.root");
38 MsgStream log(
msgSvc(), name());
40 log << MSG::INFO <<
" Creating histograms" << endreq;
43 m_histo.push_back(
new TH1F(
"deltap",
"#delta p, true momentum - rec momentum, MeV/c",600,-100,500));
45 m_histo.push_back(
new TH1F(
"n_parents",
"Number of parents for reconstructed track",20,0,20));
46 m_histo.push_back(
new TH1F(
"n_tracks",
"Number of tracks for one MC particle",20,0,20));
48 m_histo.push_back(
new TH1F(
"hit_parent",
"Number of parent MC hits for reconstructed hit",20,-10,10));
49 m_histo.push_back(
new TH1F(
"hit_track",
"Number of reconstructed hits for MC hit",20,-10,10));
51 m_histo.push_back(
new TH1F(
"true_p",
"true momentum, MeV/c",1500,0,1500));
52 m_histo.push_back(
new TH1F(
"rec_p",
"reconstructed momentum, MeV/c",1500,0,1500));
54 m_histo.push_back(
new TH1F(
"n_emcparents",
"# of parents for reconstructed shower",20,0,20));
55 m_histo.push_back(
new TH1F(
"n_showers",
"# of showers for one true particle",20,0,20));
57 m_histo.push_back(
new TH1F(
"pdg_miss",
"Pdg of particles with # trk==0 and #showers > 0",6000,-3000,3000));
59 m_histo.push_back(
new TH1F(
"dE_true",
"True energy - shower energy",40,-2000,2000));
60 m_histo.push_back(
new TH1F(
"dE_rec",
"shower energy - sqrt(Prec**2+m_true**2)",40,-2000,2000));
62 m_histo.push_back(
new TH1F(
"E_true",
"True energy, MeV",100,0,1000));
63 m_histo.push_back(
new TH1F(
"E_rec",
"Rec energy, MeV",100,0,1000));
65 m_histo2.push_back(
new TH2F(
"deltap_p",
"#delta p/p vs. p, MeV",100,0,1000,20,0,2));
67 return StatusCode::SUCCESS;
73 MsgStream log(
msgSvc(), name());
76 SmartDataPtr<EventNavigator> navigator (eventSvc(),
"/Event/Navigator");
79 log << MSG::ERROR <<
" Unable to retrieve EventNavigator" << endreq;
80 return StatusCode::FAILURE;
83 log << MSG::INFO <<
"EventNavigator object" << endreq;
88 log << MSG::INFO <<
"=======================================================================" << endreq;
89 log << MSG::INFO <<
"MC Particles ===============================================================" << endreq;
92 SmartDataPtr<McParticleCol> mcParticles(eventSvc(),
"/Event/MC/McParticleCol");
95 log << MSG::ERROR <<
" Unable to retrieve McParticleCol" << endreq;
96 return StatusCode::FAILURE;
100 for( McParticleCol::iterator it = mcParticles->begin(); it != mcParticles->end(); it++ )
103 int pdg_code = (*it)->particleProperty();
106 double true_mom = (*it)->initialFourMomentum().vect().mag();
109 m_histo[5]->Fill(true_mom);
111 log<<MSG::INFO<<
"Retrieved McParticle # "<<(*it)->trackIndex()
112 <<
" PDG " << pdg_code <<
" of true momentum "
113 << true_mom <<
" GeV/c " <<endreq;
120 m_histo[2]->Fill(tracks.size());
122 log << MSG::INFO <<
" Found " << tracks.size() <<
" tracks and " << ktracks.size() <<
" Kalman tracks" << endreq;
125 for(
unsigned int i=0; i<ktracks.size(); i++)
130 log << MSG::INFO <<
"\t Track # " << i
131 <<
" id = " << ktracks[i]->trackId()
132 <<
" Pid " << ktracks[i]->getPidType()
133 <<
" Ptot " <<
momentum <<
" GeV/c" << endreq;
136 m_histo[0]->Fill(true_mom-
momentum);
139 m_histo2[0]->Fill(true_mom, fabs(true_mom-
momentum)/true_mom);
145 m_histo[8]->Fill(showers.size());
147 log << MSG::INFO <<
" Found " << showers.size() <<
" showers" << endreq;
149 for(
unsigned int i=0; i<showers.size(); i++)
151 double true_energy = (*it)->initialFourMomentum().e();
152 double rec_energy = showers[i]->energy()*1000;
154 log << MSG::INFO <<
"\t Shower # " << i
155 <<
" Id = " << showers[i]->getShowerId().get_value()
156 <<
" E = " << showers[i]->energy()*1000 <<
" MeV " << endreq;
158 m_histo[12]->Fill(true_energy);
159 m_histo[13]->Fill(rec_energy);
163 log << MSG::INFO <<
"MDC Tracks ==============================================================" << endreq;
166 SmartDataPtr<RecMdcKalTrackCol> mdcKalTracks(eventSvc(),
"/Event/Recon/RecMdcKalTrackCol");
169 log << MSG::ERROR <<
" Unable to retrieve MdcKalTrackCol" << endreq;
170 return StatusCode::SUCCESS;
173 for( RecMdcKalTrackCol::iterator it = mdcKalTracks->begin(); it != mdcKalTracks->end(); it++ )
177 log << MSG::INFO <<
"Retrieved " << particles.size() <<
" McParticles for for MdcKalTrack # "
178 << (*it)->trackId() <<
" of reconstructed momentum " << (*it)->p() <<
" GeV/c (PID="
179 << (*it)->getPidType() <<
")" << endreq;
182 m_histo[6]->Fill((*it)->p());
185 m_histo[1]->Fill(particles.size());
188 for(
unsigned int i=0; i<particles.size(); i++)
190 int pdg_code = particles[i]->particleProperty();
193 double true_mom = particles[i]->initialFourMomentum().vect().mag();
196 int relevance = navigator->getMcParticleRelevance(*it, particles[i]);
199 log << MSG::INFO <<
"\t" << pdg_code <<
" momentum "
200 << true_mom <<
" relevance " << relevance << endreq;
205 log << MSG::INFO <<
"EMC Showers ==============================================================" << endreq;
206 SmartDataPtr<RecEmcShowerCol> emcShowers(eventSvc(),
"/Event/Recon/RecEmcShowerCol");
209 log << MSG::ERROR <<
" Unable to retrieve EmcRecShowerCol" << endreq;
210 return StatusCode::SUCCESS;
214 for( RecEmcShowerCol::iterator it = emcShowers->begin(); it != emcShowers->end(); it++ )
217 log << MSG::INFO <<
"Retrieved McParticles for EmcShower # " << ij++
218 <<
" Id " << (*it)->getShowerId().get_value()
219 <<
" Energy = " << (*it)->energy() << endreq;
221 for(
unsigned int i=0; i<particles.size(); i++)
223 int pdg_code = particles[i]->particleProperty();
226 double true_e = particles[i]->initialFourMomentum().e();
229 int relevance = navigator->getMcParticleRelevance(*it, particles[i]);
231 log <<
"\t Particle " << i <<
" PDG " << pdg_code <<
" E=" << true_e
232 <<
" Relevance " << relevance << endreq;
236 m_histo[7]->Fill(particles.size());
239 log << MSG::INFO <<
"=======================================================================" << endreq;
241 return StatusCode::SUCCESS;
249 TFile of(m_fout.c_str(),
"RECREATE");
251 for(vector<TH1F*>::iterator it=m_histo.begin(); it!=m_histo.end(); it++)
253 for(vector<TH2F*>::iterator it=m_histo2.begin(); it!=m_histo2.end(); it++)
257 return StatusCode::SUCCESS;
**********INTEGER nmxhep !maximum number of particles DOUBLE PRECISION vhep INTEGER jdahep COMMON hepevt $ !serial number $ !number of particles $ !status code $ !particle ident KF $ !parent particles $ !childreen particles $ !four momentum
std::vector< const RecMdcTrack * > RecMdcTrackVector
std::vector< const Event::McParticle * > McParticleVector
std::vector< const RecMdcKalTrack * > RecMdcKalTrackVector
std::vector< const RecEmcShower * > RecEmcShowerVector