9#include "GaudiKernel/Bootstrap.h"
10#include "GaudiKernel/ISvcLocator.h"
11#include "GaudiKernel/ISvcLocator.h"
12#include "GaudiKernel/IDataProviderSvc.h"
13#include "GaudiKernel/SmartDataPtr.h"
23 if(!m_pointer) m_pointer =
new ParticleID();
29 if(IsDedxInfoUsed()) {
34 if(IsTofInfoUsed()|IsTof1InfoUsed()|IsTof2InfoUsed()) {
39 if(IsTofCorrInfoUsed()) {
66 for(
int i = 0; i < 5; i++) {
99 cout <<
" please use ParticleID::calculate(run) ! " << endl;
110 IDataProviderSvc* m_eventSvc;
111 Gaudi::svcLocator()->service(
"EventDataSvc", m_eventSvc,
true);
113 SmartDataPtr<Event::EventHeader> eventHeaderpid(m_eventSvc,
"/Event/EventHeader");
114 int runpid=eventHeaderpid->runNumber();
115 int eventpid=eventHeaderpid->eventNumber();
131 if(m_pidcase == 0 ) {
135 if(IsDedxInfoUsed()) {
138 m_dedxpid->setRunNo(runpid);
139 m_dedxpid->setNhitCutDx(nhitcutpid);
140 m_dedxpid->setRecTrack(recTrk);
143 m_dedxpid->calculate();
147 if(IsTofInfoUsed()|IsTof1InfoUsed()|IsTof2InfoUsed()|IsTofCInfoUsed())
153 m_tofcpid->setRunNo(runpid);
154 m_tofcpid->setRecTrack(recTrk);
157 m_tofcpid->calculate();
163 m_tofpid->setRecTrack(recTrk);
166 m_tofpid->calculate();
173 if(IsTofCorrInfoUsed()) {
175 m_tofcorrpid->setRunNo(runpid);
176 m_tofcorrpid->init();
177 m_tofcorrpid->setRecTrack(recTrk);
181 m_tofcorrpid->calculate();
207 if(IsTofQInfoUsed()) {
210 m_tofqpid->setRecTrack(recTrk);
212 m_tofqpid->calculate();
216 if(IsTofEInfoUsed()&&(!IsTofCorrInfoUsed())) {
219 m_tofepid->setRecTrack(recTrk);
222 m_tofepid->calculate();
225 if(IsEmcInfoUsed()) {
228 m_emcpid->setRecTrack(recTrk);
230 m_emcpid->calculate();
234 if(IsMucInfoUsed()) {
237 m_mucpid->setRecTrack(recTrk);
239 m_mucpid->calculate();
256int ParticleID ::particleIDCalculation() {
262 if(!valid)
return irc;
266 for(
int i = 0; i < 5; i++) {
280 if(IsDedxInfoUsed()) {
283 for(
int i = 0; i < 5; i++) {
284 if(pidcase[i] && (fabs(
chiDedx(i)) < m_dedxpid->chiMinCut()))
285 if(!okpid) okpid =
true;
299 if(IsTofInfoUsed()|IsTof1InfoUsed()|IsTof2InfoUsed() | IsTofCInfoUsed())
300 {
if(IsTofCInfoUsed())
304 for(
int i = 0; i < 5; i++) {
305 if(pidcase[i] && (fabs(
chiTofC(i)) < m_tofcpid->chiMinCut()))
306 if(!okpid) okpid =
true;
317 for(
int i = 0; i < 5; i++) {
318 if(pidcase[i] && (fabs(
chiTof(i)) < m_tofpid->chiMinCut()))
319 if(!okpid) okpid =
true;
323 for(
int i = 0; i < 5; i++) chisq[i] +=
chiTof(i)*
chiTof(i);
332 if(IsTofEInfoUsed()) {
335 for(
int i = 0; i < 5; i++) {
336 if(pidcase[i] && (fabs(
chiTofE(i)) < m_tofepid->chiMinCut()))
337 if(!okpid) okpid =
true;
350 if(IsTofCorrInfoUsed()) {
353 for(
int i = 0; i < 5; i++) {
354 if(pidcase[i] && (
chiTofCorr(i) < m_tofcorrpid->chiMaxCut() ) && (
chiTofCorr(i) > ( 0.0 - m_tofcorrpid->chiMinCut() ) ) )
356 if(!okpid) okpid =
true;
369 if(IsTofQInfoUsed()) {
372 for(
int i = 0; i < 5; i++) {
373 if(pidcase[i] && (fabs(
chiTofQ(i)) < m_tofqpid->chiMinCut()))
374 if(!okpid) okpid =
true;
384 if(IsMucInfoUsed()) {
387 for(
int i = 0; i < 5; i++) {
388 if(pidcase[i] && (fabs(
chiMuc(i)) < m_mucpid->chiMinCut()))
389 if(!okpid) okpid =
true;
393 for(
int i = 0; i < 5; i++) chisq[i] +=
chiMuc(i)*
chiMuc(i);
400 if(IsEmcInfoUsed()) {
403 for(
int i = 0; i < 5; i++) {
404 if(pidcase[i] && (fabs(
chiEmc(i)) < m_emcpid->chiMinCut()))
405 if(!okpid) okpid =
true;
409 for(
int i = 0; i < 5; i++) chisq[i] +=
chiEmc(i)*
chiEmc(i);
415 if(m_ndof <= 0)
return irc;
418 for(
int i = 0; i < 5; i++) {
419 m_chisq[i] = chisq[i];
436 if(!valid)
return irc;
439 for(
int i = 0; i < 5; i++) {
450 for(
int i = 0; i < 5; i++) {
458 if(IsDedxInfoUsed()) {
461 for(
int i = 0; i < 5; i++) {
463 if(!okpid) okpid =
true;
467 for(
int i = 0; i < 5; i++) {
478 if(IsTofInfoUsed()|IsTof1InfoUsed()|IsTof2InfoUsed()|IsTofCInfoUsed())
479 {
if(IsTofCInfoUsed())
484 for(
int i = 0; i < 5; i++) {
486 if(!okpid) okpid =
true;
490 for(
int i = 0; i < 5; i++) {
500 for(
int i = 0; i < 5; i++) {
502 if(!okpid) okpid =
true;
506 for(
int i = 0; i < 5; i++) {
518 if(IsTofEInfoUsed()) {
521 for(
int i = 0; i < 5; i++) {
523 if(!okpid) okpid =
true;
536 if(IsTofCorrInfoUsed()) {
539 for(
int i = 0; i < 5; i++) {
541 if(!okpid) okpid =
true;
545 for(
int i = 0; i < 5; i++) {
559 for(
int i = 0; i < 5; i++) {
561 if(!okpid) okpid =
true;
565 for(
int i = 0; i < 5; i++)
pdf[i] *=
pdfTofQ(i);
572 if(IsEmcInfoUsed()) {
575 for(
int i = 0; i < 5; i++) {
576 if(pidcase[i]&&
pdfEmc(i)>0)
577 if(!okpid) okpid =
true;
581 for(
int i = 0; i < 5; i++) {
587 if(IsMucInfoUsed()) {
590 for(
int i = 0; i < 5; i++) {
591 if(pidcase[i]&&
pdfMuc(i)>0)
592 if(!okpid) okpid =
true;
596 for(
int i = 0; i < 5; i++) {
605 if(m_ndof <= 0)
return irc;
606 for(
int i = 0; i < 5; i++) {
608 m_TotalLikelihood +=
pdf[i];
610 for(
int i = 0; i < 5; i++) {
611 m_likelihoodfraction[i] =
pdf[i]/m_TotalLikelihood;
static DedxPID * instance()
static EmcPID * instance()
static MucPID * instance()
EvtRecTrack * PidTrk() const
double probCalculate(double chi2, int n)
int methodProbability() const
double pdfCalculate(double offset, double sigma)
double pdfMinSigmaCut() const
int methodNeuronNetwork() const
void setChiMaxCut(const double chi=6)
void setChiMinCut(const double chi=4)
int methodLikelihood() const
double chiMuc(int n) const
bool IsTofEInfoValid() const
bool IsEmcInfoValid() const
int LikelihoodCalculation()
double chiTofE(int n) const
bool IsTofCorrInfoValid() const
bool IsTofCInfoValid() const
bool IsTofInfoValid() const
double chiTofQ(int n) const
bool IsTofQInfoValid() const
int particleIDCalculation()
static ParticleID * instance()
bool IsDedxInfoValid() const
double chiTofC(int n) const
double chiEmc(int n) const
bool IsMucInfoValid() const
double chiTof(int n) const
double chiTofCorr(int n) const
double chiDedx(int n) const
static TofCPID * instance()
static TofCorrPID * instance()
static TofEPID * instance()
static TofPID * instance()
static TofQPID * instance()