1#include "GaudiKernel/IDataProviderSvc.h"
2#include "GaudiKernel/MsgStream.h"
3#include "GaudiKernel/SmartDataPtr.h"
23 declareProperty(
"DedxChiCut", m_dedx_chi_cut = 4);
24 declareProperty(
"TofChiCut", m_tof_chi_cut = 4);
25 declareProperty(
"IsTofCorr", m_tof_corr =
true);
26 declareProperty(
"IsDedxCorr", m_dedx_corr =
true);
27 declareProperty(
"EidRatio", m_eid_ratio = 0.80);
34 MsgStream log(messageService(), name());
35 log << MSG::INFO <<
"in SimplePIDSvc initialize()" << endreq;
37 StatusCode sc = Service::initialize();
39 sc = serviceLocator()->service(
"EventDataSvc", eventSvc_,
true);
49 MsgStream log(messageService(), name());
50 log << MSG::INFO <<
"in SimplePIDSvc finalize()" << endreq;
52 StatusCode sc = Service::finalize();
54 for (
unsigned int i = 0; i < 2; i++)
56 for (
unsigned int j = 0; j < 4; j++)
58 f_dedx[i][j]->Close();
59 f_tof_q[i][j]->Close();
60 f_tof_bgcost[i][j]->Close();
61 f_tof_wgt[i][j]->Close();
62 f_tof_final[i][j]->Close();
63 f_tofec_q[i][j]->Close();
64 f_tofec_bg[i][j]->Close();
65 f_tofec_cost[i][j]->Close();
68 for (
unsigned int i = 0; i < 3; i++)
70 for (
unsigned int j = 0; j < 4; j++)
98 SmartDataPtr<Event::EventHeader> eventHeaderpid(eventSvc_,
"/Event/EventHeader");
99 m_run = eventHeaderpid->runNumber();
118 for(
unsigned int pid = 0; pid < 5; pid++)
121 m_p[pid] = mdckalTrk->
p();
122 m_betagamma[pid] = m_p[pid] /
mass[pid];
123 m_charge[pid] = mdckalTrk->
charge();
124 m_cost[pid] =
cos(mdckalTrk->
theta());
129 for(
unsigned int i = 0; i < 5; i++)
132 m_betagamma[i] = -99;
144 dedxSecondCorrection();
150 if (m_tof_barrel == 1)
152 tofBarrelCorrection();
153 tofBarrelSecondCorrection();
155 else if (m_tof_barrel == 0)
157 tofEndcapCorrection();
158 tofEndcapSecondCorrection();
167void SimplePIDSvc::calprob()
169 bool usededx =
false;
172 for (
unsigned int i = 0; i < 5 ;i++)
174 if (!usededx && fabs(m_dedx_chi[i]) < m_dedx_chi_cut)
176 if (!usetof && fabs(m_tof_chi[i]) < m_tof_chi_cut)
179 m_dedx_only[i] =
false;
183 for(
unsigned int i = 0; i < 5; i++)
188 for(
unsigned int i = 0; i < 5; i++)
192 for (
unsigned int i = 0; i < 5; i++)
198 if (usededx && usetof)
200 chi2 = pow(m_dedx_chi[i], 2) + pow(m_tof_chi[i], 2);
203 else if (usededx && !usetof)
205 chi2 = pow(m_dedx_chi[i], 2);
207 m_dedx_only[i] =
true;
209 else if (!usededx && usetof)
211 chi2 = pow(m_tof_chi[i],2);
214 if (ndf > 0 && chi2 > 0)
215 m_prob[i] = TMath::Prob(chi2, ndf);
219int SimplePIDSvc::getRunIdx(
int run_no)
226 const int RUN_BEGIN_DATA_10 = 11414;
227 const int RUN_END_DATA_10 = 14604;
228 const int RUN_BEGIN_MC_10 = -14604;
229 const int RUN_END_MC_10 = -11414;
230 const int RUN_BEGIN_DATA_11 = 20448;
231 const int RUN_END_DATA_11 = 23454;
232 const int RUN_BEGIN_MC_11 = -23454;
233 const int RUN_END_MC_11 = -20448;
235 const int RUN_BEGIN_DATA_22 = 70521;
236 const int RUN_END_DATA_22 = 73930;
237 const int RUN_BEGIN_MC_22 = -73930;
238 const int RUN_END_MC_22 = -70521;
240 const int RUN_BEGIN_DATA_23 = 74031;
241 const int RUN_END_DATA_23 = 78536;
242 const int RUN_BEGIN_MC_23 = -78536;
243 const int RUN_END_MC_23 = -74031;
245 const int RUN_BEGIN_DATA_24 = 78615;
246 const int RUN_END_DATA_24 = 81094;
247 const int RUN_BEGIN_MC_24 = -81094;
248 const int RUN_END_MC_24 = -78615;
250 const int RUN_BEGIN_DATA_OffRes_24 = 81095;
251 const int RUN_END_DATA_OffRes_24 = 81631;
252 const int RUN_BEGIN_MC_OffRes_24 = -81631;
253 const int RUN_END_MC_OffRes_24 = -81095;
255 if (run_no >= RUN_BEGIN_DATA_10 && run_no <= RUN_END_DATA_10)
257 else if (run_no >= RUN_BEGIN_DATA_11 && run_no <= RUN_END_DATA_11)
259 else if (run_no >= RUN_BEGIN_MC_10 && run_no <= RUN_END_MC_10)
261 else if (run_no >= RUN_BEGIN_MC_11 && run_no <= RUN_END_MC_11)
264 else if (run_no >= RUN_BEGIN_DATA_22 && run_no <= RUN_END_DATA_22)
266 else if (run_no >= RUN_BEGIN_MC_22 && run_no <= RUN_END_MC_22)
268 else if (run_no >= RUN_BEGIN_DATA_23 && run_no <= RUN_END_DATA_23)
270 else if (run_no >= RUN_BEGIN_MC_23 && run_no <= RUN_END_MC_23)
272 else if (run_no >= RUN_BEGIN_DATA_24 && run_no <= RUN_END_DATA_24)
274 else if (run_no >= RUN_BEGIN_MC_24 && run_no <= RUN_END_MC_24)
276 else if (run_no >= RUN_BEGIN_DATA_OffRes_24 && run_no <= RUN_END_DATA_OffRes_24)
278 else if (run_no >= RUN_BEGIN_MC_OffRes_24 && run_no <= RUN_END_MC_OffRes_24)
288 for (
unsigned int i = 0; i < 8; i++)
290 for (
unsigned int j = 0; j < 5; j++)
291 m_tof_dt[i][j] = -99.;
294 for (
unsigned int i = 0; i < 2; i++)
296 m_tof_zr[i] = -9999.;
297 m_tof_counter[i] = -1;
299 for (
unsigned int i = 0; i < 5; i++)
307 SmartRefVector<RecTofTrack> tofTrk = track->
tofTrack();
308 SmartRefVector<RecTofTrack>::iterator it;
309 RecExtTrack* extTrk = track->
extTrack();
314 TofHitStatus *hitst =
new TofHitStatus;
316 for (it = tofTrk.begin(); it != tofTrk.end(); it++)
318 unsigned int st = (*it)->status();
320 if (hitst->
is_raw())
continue;
325 int layer = hitst->
layer();
326 double tof = (*it)->tof();
327 double ph = (*it)->ph();
328 m_tof_counter[layer-1] = (*it)->tofID();
339 m_tof_zr[0] = zrhit[0];
340 m_tof_zr[1] = zrhit[1];
346 idx = ((st & 0xC0) >> 5) + (((st ^ 0x20) & 0x20) >> 5) - 2;
358 if (idx == -1)
continue;
360 for (
unsigned int i = 0; i < 5; i++)
362 double offset = (*it)->toffset(i);
363 double texp = (*it)->texp(i);
364 if (texp < 0.0)
continue;
365 double dt = tof - offset - texp;
366 m_tof_dt[idx][i] =
dt;
372void SimplePIDSvc::tofBarrelCorrection()
374 const double EPS = 1e-4;
375 const double BG_LOW = 0.20;
376 const double BG_UP = 7.40;
377 const double COST_LOW = -0.81;
378 const double COST_UP = 0.81;
379 const double Q_LOW = 0.;
380 const double Q_UP = 9000.;
381 const double P_LOW = 0.2;
382 const double P_UP = 1.3;
383 const int BIN_BG = 15;
384 const int BIN_COST = 15;
385 const int BIN_P = 15;
386 double BG[BIN_BG + 1] = {0.20, 0.87, 1.11, 1.35, 1.55, 1.72, 1.91, 2.17, 2.63, 3.05, 3.47, 3.93, 4.50, 5.27, 6.00, 7.40};
387 double COST[BIN_COST + 1] = {-0.81, -0.64, -0.53, -0.43, -0.33, -0.23, -0.13, -0.04, 0.05, 0.14, 0.24, 0.34, 0.44, 0.54, 0.65, 0.81};
388 double P[BIN_P + 1] = {0.20, 0.47, 0.56, 0.65, 0.72, 0.79, 0.86, 0.92, 0.98, 1.03, 1.08, 1.13, 1.17, 1.22, 1.26, 1.30};
389 int idx = getRunIdx(m_run);
393 for (
unsigned int i = 0; i < 4; i++)
396 int bin_bg, bin_cost, bin_wgt;
401 bin_bg = findBin(
P, BIN_P,
bg);
404 else if (i == 2 || i == 3)
407 bin_bg = findBin(BG, BIN_BG,
bg);
414 double cost = m_cost[i];
417 double offset,
sigma;
418 double offset_q, offset_bgcost;
419 int flag[4] = {0, 0, 0, 0, };
421 bin_cost = findBin(COST, BIN_COST, cost);
422 if (bin_bg == -1 || bin_cost == -1)
continue;
425 for (
unsigned int j = 0; j < 4; j++)
427 t[j] = m_tof_dt[j][i];
428 if (fabs(
t[j] + 99.) <
EPS)
436 offset_q = h_tof_p_q_offset[pid][idx][j]->Interpolate(
q );
437 offset_bgcost = h_tof_p_bgcost_offset[pid][idx][j]->Interpolate(
bg, cost );
438 t[j] =
t[j] - offset_q - offset_bgcost;
442 offset_q = h_tof_m_q_offset[pid][idx][j]->Interpolate(
q );
443 offset_bgcost = h_tof_m_bgcost_offset[pid][idx][j]->Interpolate(
bg, cost );
444 t[j] =
t[j] - offset_q - offset_bgcost;
448 if (bin_wgt == -1)
continue;
450 for (
unsigned int j = 0; j < 4; j++)
453 t[4] +=
t[j] * h_tof_p_wgt[pid][idx][bin_wgt][j]->GetBinContent( bin_bg+1, bin_cost+1 );
455 t[4] +=
t[j] * h_tof_m_wgt[pid][idx][bin_wgt][j]->GetBinContent( bin_bg+1, bin_cost+1 );
459 t[4] /= h_tof_p_wgt[pid][idx][bin_wgt][4]->GetBinContent( bin_bg+1, bin_cost+1 );
460 offset = h_tof_p_final_offset[pid][idx][bin_wgt]->Interpolate(
bg, cost );
461 sigma = h_tof_p_final_sigma[pid][idx][bin_wgt]-> Interpolate(
bg, cost );
462 m_tof_chi[i] = (
t[4] - offset) /
sigma;
466 t[4] /= h_tof_m_wgt[pid][idx][bin_wgt][4]->GetBinContent( bin_bg+1, bin_cost+1 );
467 offset = h_tof_m_final_offset[pid][idx][bin_wgt]->Interpolate(
bg, cost );
468 sigma = h_tof_m_final_sigma[pid][idx][bin_wgt]-> Interpolate(
bg, cost );
469 m_tof_chi[i] = (
t[4] - offset) /
sigma;
475void SimplePIDSvc::tofEndcapCorrection()
477 const double EPS = 1e-4;
478 const double BG_LOW = 0.30;
479 const double BG_UP = 7.40;
480 const double Q_LOW = 0.;
481 const double Q_UP = 6000.;
482 const double COST_EAST_LOW = 0.720;
483 const double COST_EAST_UP = 0.930;
484 const double COST_WEST_LOW = -0.930;
485 const double COST_WEST_UP = -0.720;
486 const double P_LOW = 0.2;
487 const double P_UP = 1.3;
489 int idx = getRunIdx(m_run);
493 for (
unsigned int i = 0; i < 4; i++)
502 else if (i == 2 || i == 3)
513 double cost = m_cost[i];
515 double t = m_tof_dt[7][i];
516 double q = m_tof_ph[7];
517 double off_q, off_bg, off_cost;
518 double sg_q, sg_bg, sg_cost;
522 cost =
max(COST_EAST_LOW+
EPS,
min(COST_EAST_UP-
EPS, cost));
527 cost =
max(COST_WEST_LOW+
EPS,
min(COST_WEST_UP-
EPS, cost));
534 off_q = h_tofec_p_q_offset[pid][idx][
flag] ->Interpolate(
q );
535 sg_q = h_tofec_p_q_sigma[pid][idx][
flag] ->Interpolate(
q );
536 off_bg = h_tofec_p_bg_offset[pid][idx][
flag] ->Interpolate(
bg );
537 sg_bg = h_tofec_p_bg_sigma[pid][idx][
flag] ->Interpolate(
bg );
538 off_cost = h_tofec_p_cost_offset[pid][idx][
flag]->Interpolate( cost );
539 sg_cost = h_tofec_p_cost_sigma[pid][idx][
flag] ->Interpolate( cost );
540 m_tof_chi[i] = (((
t - off_q) / sg_q - off_bg) / sg_bg - off_cost) / sg_cost;
544 off_q = h_tofec_m_q_offset[pid][idx][
flag] ->Interpolate(
q );
545 sg_q = h_tofec_m_q_sigma[pid][idx][
flag] ->Interpolate(
q );
546 off_bg = h_tofec_m_bg_offset[pid][idx][
flag] ->Interpolate(
bg );
547 sg_bg = h_tofec_m_bg_sigma[pid][idx][
flag] ->Interpolate(
bg );
548 off_cost = h_tofec_m_cost_offset[pid][idx][
flag]->Interpolate( cost );
549 sg_cost = h_tofec_m_cost_sigma[pid][idx][
flag] ->Interpolate( cost );
550 m_tof_chi[i] = (((
t - off_q) / sg_q - off_bg) / sg_bg - off_cost) / sg_cost;
560 RecMdcDedx* dedx_trk = track->
mdcDedx();
561 for (
unsigned int i = 0; i < 5; i++)
562 m_dedx_chi[i] = dedx_trk->
chi(i);
566 for (
unsigned int i = 0; i < 5; i++)
571void SimplePIDSvc::dedxCorrection()
573 int idx = getRunIdx(m_run);
574 const double EPS = 1e-4;
575 const double BG_LOW = 0.20;
576 const double BG_UP = 7.40;
577 const double COST_LOW = -0.93;
578 const double COST_UP = 0.93;
579 const double P_LOW = 0.2;
580 const double P_UP = 1.3;
583 double offset,
sigma;
584 for (
unsigned int i = 0; i < 4; i++)
593 else if (i == 2 || i == 3)
602 double cost = m_cost[i];
603 double charge = m_charge[i];
607 offset = h_dedx_p_offset[pid][idx]->Interpolate(
bg, cost );
608 sigma = h_dedx_p_sigma[pid][idx] ->Interpolate(
bg, cost );
609 m_dedx_chi[i] = (m_dedx_chi[i] - offset) /
sigma;
613 offset = h_dedx_m_offset[pid][idx]->Interpolate(
bg, cost );
614 sigma = h_dedx_m_sigma[pid][idx] ->Interpolate(
bg, cost );
615 m_dedx_chi[i] = (m_dedx_chi[i] - offset) /
sigma;
621void SimplePIDSvc::tofBarrelSecondCorrection()
624 int idx = getRunIdx(m_run);
625 const double EPS = 1e-4;
626 const double P_LOW = 0.0;
627 const double P_UP = 1.3;
628 const int BIN_P = 10;
630 const int RUN_BEGIN_DATA_10 = 11414;
631 const int RUN_END_DATA_10 = 14604;
632 const int RUN_BEGIN_MC_10 = -14604;
633 const int RUN_END_MC_10 = -11414;
634 const int RUN_BEGIN_DATA_11 = 20448;
635 const int RUN_END_DATA_11 = 23454;
636 const int RUN_BEGIN_MC_11 = -23454;
637 const int RUN_END_MC_11 = -20448;
639 const int RUN_BEGIN_DATA_22 = 70521;
640 const int RUN_END_DATA_22 = 73930;
641 const int RUN_BEGIN_MC_22 = -73930;
642 const int RUN_END_MC_22 = -70521;
644 const int RUN_BEGIN_DATA_23 = 74031;
645 const int RUN_END_DATA_23 = 78536;
646 const int RUN_BEGIN_MC_23 = -78536;
647 const int RUN_END_MC_23 = -74031;
649 const int RUN_BEGIN_DATA_24 = 78615;
650 const int RUN_END_DATA_24 = 81094;
651 const int RUN_BEGIN_MC_24 = -81094;
652 const int RUN_END_MC_24 = -78615;
654 const int RUN_BEGIN_DATA_OffRes_24 = 81095;
655 const int RUN_END_DATA_OffRes_24 = 81631;
656 const int RUN_BEGIN_MC_OffRes_24 = -81631;
657 const int RUN_END_MC_OffRes_24 = -81095;
659 double P[BIN_P + 1] = {0.0, 0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9, 1.3};
663 for (
unsigned int i = 2; i < 4; i++){
670 bin_p = findBin(
P, BIN_P, ptk);
674 if((m_run>=RUN_BEGIN_DATA_10 && m_run<=RUN_END_DATA_10 && idx == 0)||(m_run>=RUN_BEGIN_DATA_11 && m_run<=RUN_END_DATA_11 && idx == 1))
677 if((m_run>=RUN_BEGIN_MC_10 && m_run<=RUN_END_MC_10 && idx == 2)||(m_run>=RUN_BEGIN_MC_11 && m_run<=RUN_END_MC_11 && idx == 3))
680 if(m_run>=RUN_BEGIN_DATA_22 && m_run<=RUN_END_DATA_22 && idx == 1)
683 if(m_run>=RUN_BEGIN_MC_22 && m_run<=RUN_END_MC_22 && idx == 3)
686 if(m_run>=RUN_BEGIN_DATA_23 && m_run<=RUN_END_DATA_23 && idx == 1)
689 if(m_run>=RUN_BEGIN_MC_23 && m_run<=RUN_END_MC_23 && idx == 3)
692 if(m_run>=RUN_BEGIN_DATA_24 && m_run<=RUN_END_DATA_24 && idx == 1)
695 if(m_run>=RUN_BEGIN_MC_24 && m_run<=RUN_END_MC_24 && idx == 3)
698 if(m_run>=RUN_BEGIN_DATA_OffRes_24 && m_run<=RUN_END_DATA_OffRes_24 && idx == 1)
701 if(m_run>=RUN_BEGIN_MC_OffRes_24 && m_run<=RUN_END_MC_OffRes_24 && idx == 3)
708 if((m_run>=RUN_BEGIN_DATA_10 && m_run<=RUN_END_DATA_10 && idx == 0)||(m_run>=RUN_BEGIN_DATA_11 && m_run<=RUN_END_DATA_11 && idx == 1))
711 if((m_run>=RUN_BEGIN_MC_10 && m_run<=RUN_END_MC_10 && idx == 2)||(m_run>=RUN_BEGIN_MC_11 && m_run<=RUN_END_MC_11 && idx == 3))
714 if(m_run>=RUN_BEGIN_DATA_22 && m_run<=RUN_END_DATA_22 && idx == 1)
717 if(m_run>=RUN_BEGIN_MC_22 && m_run<=RUN_END_MC_22 && idx == 3)
720 if(m_run>=RUN_BEGIN_DATA_23 && m_run<=RUN_END_DATA_23 && idx == 1)
723 if(m_run>=RUN_BEGIN_MC_23 && m_run<=RUN_END_MC_23 && idx == 3)
726 if(m_run>=RUN_BEGIN_DATA_24 && m_run<=RUN_END_DATA_24 && idx == 1)
729 if(m_run>=RUN_BEGIN_MC_24 && m_run<=RUN_END_MC_24 && idx == 3)
732 if(m_run>=RUN_BEGIN_DATA_OffRes_24 && m_run<=RUN_END_DATA_OffRes_24 && idx == 1)
735 if(m_run>=RUN_BEGIN_MC_OffRes_24 && m_run<=RUN_END_MC_OffRes_24 && idx == 3)
740 if(m_tof_chi[i]!=-99 && m_run>0){
745 if(!((m_run>=RUN_BEGIN_DATA_23 && m_run<=RUN_END_DATA_23)||(m_run>=RUN_BEGIN_DATA_24 && m_run<=RUN_END_DATA_24)||(m_run>=RUN_BEGIN_DATA_OffRes_24 && m_run<=RUN_END_DATA_OffRes_24))){
747 m_tof_chi[i] = (m_tof_chi[i] - m_gaussion_mean[aa][bb][bin_p]) / (m_gaussion_sigmab[aa][bb][bin_p] / m_gaussion_sigmab[aa][bb+1][bin_p]);
750 m_tof_chi[i] = (m_tof_chi[i] - m_gaussion_mean[aa][bb][bin_p]);
755 m_tof_chi[i] = (m_tof_chi[i] - m_gaussion_mean[aa][bb][bin_p]) / (m_gaussion_sigmab[aa][bb][bin_p] / m_gaussion_sigmab[aa][bb+1][bin_p]);
758 m_tof_chi[i] = (m_tof_chi[i] - m_gaussion_mean[aa][bb][bin_p]);
763 if(m_tof_chi[i]!=-99 && m_run<0){
764 m_tof_chi[i] = (m_tof_chi[i] - m_gaussion_mean[aa][bb][bin_p]) / (m_gaussion_sigmab[aa][bb][bin_p] / m_gaussion_sigmab[aa][bb][bin_p]);
773void SimplePIDSvc::tofEndcapSecondCorrection()
776 int idx = getRunIdx(m_run);
777 const double EPS = 1e-4;
778 const double P_LOW = 0.0;
779 const double P_UP = 1.3;
780 const int BIN_P = 10;
782 const int RUN_BEGIN_DATA_10 = 11414;
783 const int RUN_END_DATA_10 = 14604;
784 const int RUN_BEGIN_MC_10 = -14604;
785 const int RUN_END_MC_10 = -11414;
786 const int RUN_BEGIN_DATA_11 = 20448;
787 const int RUN_END_DATA_11 = 23454;
788 const int RUN_BEGIN_MC_11 = -23454;
789 const int RUN_END_MC_11 = -20448;
791 const int RUN_BEGIN_DATA_22 = 70521;
792 const int RUN_END_DATA_22 = 73930;
793 const int RUN_BEGIN_MC_22 = -73930;
794 const int RUN_END_MC_22 = -70521;
796 const int RUN_BEGIN_DATA_23 = 74031;
797 const int RUN_END_DATA_23 = 78536;
798 const int RUN_BEGIN_MC_23 = -78536;
799 const int RUN_END_MC_23 = -74031;
801 const int RUN_BEGIN_DATA_24 = 78615;
802 const int RUN_END_DATA_24 = 81094;
803 const int RUN_BEGIN_MC_24 = -81094;
804 const int RUN_END_MC_24 = -78615;
806 const int RUN_BEGIN_DATA_OffRes_24 = 81095;
807 const int RUN_END_DATA_OffRes_24 = 81631;
808 const int RUN_BEGIN_MC_OffRes_24 = -81631;
809 const int RUN_END_MC_OffRes_24 = -81095;
811 double P[BIN_P + 1] = {0.0, 0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9, 1.3};
815 for (
unsigned int i = 2; i < 4; i++){
822 bin_p = findBin(
P, BIN_P, ptk);
826 if((m_run>=RUN_BEGIN_DATA_10 && m_run<=RUN_END_DATA_10 && idx == 0)||(m_run>=RUN_BEGIN_DATA_11 && m_run<=RUN_END_DATA_11 && idx == 1))
829 if((m_run>=RUN_BEGIN_MC_10 && m_run<=RUN_END_MC_10 && idx == 2)||(m_run>=RUN_BEGIN_MC_11 && m_run<=RUN_END_MC_11 && idx == 3))
832 if(m_run>=RUN_BEGIN_DATA_22 && m_run<=RUN_END_DATA_22 && idx == 1)
835 if(m_run>=RUN_BEGIN_MC_22 && m_run<=RUN_END_MC_22 && idx == 3)
838 if(m_run>=RUN_BEGIN_DATA_23 && m_run<=RUN_END_DATA_23 && idx == 1)
841 if(m_run>=RUN_BEGIN_MC_23 && m_run<=RUN_END_MC_23 && idx == 3)
844 if(m_run>=RUN_BEGIN_DATA_24 && m_run<=RUN_END_DATA_24 && idx == 1)
847 if(m_run>=RUN_BEGIN_MC_24 && m_run<=RUN_END_MC_24 && idx == 3)
850 if(m_run>=RUN_BEGIN_DATA_OffRes_24 && m_run<=RUN_END_DATA_OffRes_24 && idx == 1)
853 if(m_run>=RUN_BEGIN_MC_OffRes_24 && m_run<=RUN_END_MC_OffRes_24 && idx == 3)
860 if((m_run>=RUN_BEGIN_DATA_10 && m_run<=RUN_END_DATA_10 && idx == 0)||(m_run>=RUN_BEGIN_DATA_11 && m_run<=RUN_END_DATA_11 && idx == 1))
863 if((m_run>=RUN_BEGIN_MC_10 && m_run<=RUN_END_MC_10 && idx == 2)||(m_run>=RUN_BEGIN_MC_11 && m_run<=RUN_END_MC_11 && idx == 3))
866 if(m_run>=RUN_BEGIN_DATA_22 && m_run<=RUN_END_DATA_22 && idx == 1)
869 if(m_run>=RUN_BEGIN_MC_22 && m_run<=RUN_END_MC_22 && idx == 3)
872 if(m_run>=RUN_BEGIN_DATA_23 && m_run<=RUN_END_DATA_23 && idx == 1)
875 if(m_run>=RUN_BEGIN_MC_23 && m_run<=RUN_END_MC_23 && idx == 3)
878 if(m_run>=RUN_BEGIN_DATA_24 && m_run<=RUN_END_DATA_24 && idx == 1)
881 if(m_run>=RUN_BEGIN_MC_24 && m_run<=RUN_END_MC_24 && idx == 3)
884 if(m_run>=RUN_BEGIN_DATA_OffRes_24 && m_run<=RUN_END_DATA_OffRes_24 && idx == 1)
887 if(m_run>=RUN_BEGIN_MC_OffRes_24 && m_run<=RUN_END_MC_OffRes_24 && idx == 3)
892 if(m_tof_chi[i]!=-99 && ( aa==5 || aa==8 || aa==11)){
894 m_tof_chi[i] = (m_tof_chi[i] - m_gaussion_mean[aa][bb][bin_p]) / (60./110.);
898 if(m_tof_chi[i]!=-99 && aa==4){
900 m_tof_chi[i] = (m_tof_chi[i] - m_gaussion_mean[aa][bb][bin_p]);
912void SimplePIDSvc::dedxSecondCorrection()
916 int idx = getRunIdx(m_run);
917 const double EPS = 1e-4;
918 const double P_LOW = 0.0;
919 const double P_UP = 1.3;
920 const int BIN_P = 10;
922 const int RUN_BEGIN_DATA_10 = 11414;
923 const int RUN_END_DATA_10 = 14604;
924 const int RUN_BEGIN_MC_10 = -14604;
925 const int RUN_END_MC_10 = -11414;
926 const int RUN_BEGIN_DATA_11 = 20448;
927 const int RUN_END_DATA_11 = 23454;
928 const int RUN_BEGIN_MC_11 = -23454;
929 const int RUN_END_MC_11 = -20448;
931 const int RUN_BEGIN_DATA_22 = 70521;
932 const int RUN_END_DATA_22 = 73930;
933 const int RUN_BEGIN_MC_22 = -73930;
934 const int RUN_END_MC_22 = -70521;
936 const int RUN_BEGIN_DATA_23 = 74031;
937 const int RUN_END_DATA_23 = 78536;
938 const int RUN_BEGIN_MC_23 = -78536;
939 const int RUN_END_MC_23 = -74031;
941 const int RUN_BEGIN_DATA_24 = 78615;
942 const int RUN_END_DATA_24 = 81094;
943 const int RUN_BEGIN_MC_24 = -81094;
944 const int RUN_END_MC_24 = -78615;
946 const int RUN_BEGIN_DATA_OffRes_24 = 81095;
947 const int RUN_END_DATA_OffRes_24 = 81631;
948 const int RUN_BEGIN_MC_OffRes_24 = -81631;
949 const int RUN_END_MC_OffRes_24 = -81095;
951 double P[BIN_P + 1] = {0.0, 0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9, 1.3};
955 for (
unsigned int i = 2; i < 4; i++){
962 bin_p = findBin(
P, BIN_P, ptk);
966 if((m_run>=RUN_BEGIN_DATA_10 && m_run<=RUN_END_DATA_10 && idx == 0)||(m_run>=RUN_BEGIN_DATA_11 && m_run<=RUN_END_DATA_11 && idx == 1))
969 if((m_run>=RUN_BEGIN_MC_10 && m_run<=RUN_END_MC_10 && idx == 2)||(m_run>=RUN_BEGIN_MC_11 && m_run<=RUN_END_MC_11 && idx == 3))
972 if(m_run>=RUN_BEGIN_DATA_22 && m_run<=RUN_END_DATA_22 && idx == 1)
975 if(m_run>=RUN_BEGIN_MC_22 && m_run<=RUN_END_MC_22 && idx == 3)
978 if(m_run>=RUN_BEGIN_DATA_23 && m_run<=RUN_END_DATA_23 && idx == 1)
981 if(m_run>=RUN_BEGIN_MC_23 && m_run<=RUN_END_MC_23 && idx == 3)
984 if(m_run>=RUN_BEGIN_DATA_24 && m_run<=RUN_END_DATA_24 && idx == 1)
987 if(m_run>=RUN_BEGIN_MC_24 && m_run<=RUN_END_MC_24 && idx == 3)
990 if(m_run>=RUN_BEGIN_DATA_OffRes_24 && m_run<=RUN_END_DATA_OffRes_24 && idx == 1)
993 if(m_run>=RUN_BEGIN_MC_OffRes_24 && m_run<=RUN_END_MC_OffRes_24 && idx == 3)
1000 if((m_run>=RUN_BEGIN_DATA_10 && m_run<=RUN_END_DATA_10 && idx == 0)||(m_run>=RUN_BEGIN_DATA_11 && m_run<=RUN_END_DATA_11 && idx == 1))
1003 if((m_run>=RUN_BEGIN_MC_10 && m_run<=RUN_END_MC_10 && idx == 2)||(m_run>=RUN_BEGIN_MC_11 && m_run<=RUN_END_MC_11 && idx == 3))
1006 if(m_run>=RUN_BEGIN_DATA_22 && m_run<=RUN_END_DATA_22 && idx == 1)
1009 if(m_run>=RUN_BEGIN_MC_22 && m_run<=RUN_END_MC_22 && idx == 3)
1012 if(m_run>=RUN_BEGIN_DATA_23 && m_run<=RUN_END_DATA_23 && idx == 1)
1015 if(m_run>=RUN_BEGIN_MC_23 && m_run<=RUN_END_MC_23 && idx == 3)
1018 if(m_run>=RUN_BEGIN_DATA_24 && m_run<=RUN_END_DATA_24 && idx == 1)
1021 if(m_run>=RUN_BEGIN_MC_24 && m_run<=RUN_END_MC_24 && idx == 3)
1024 if(m_run>=RUN_BEGIN_DATA_OffRes_24 && m_run<=RUN_END_DATA_OffRes_24 && idx == 1)
1027 if(m_run>=RUN_BEGIN_MC_OffRes_24 && m_run<=RUN_END_MC_OffRes_24 && idx == 3)
1032 if(m_dedx_chi[i]!=-99 && m_run>0){
1033 m_dedx_chi[i] = (m_dedx_chi[i] - m_gaussion_mean[aa][bb][bin_p]) / (m_gaussion_sigmab[aa][bb][bin_p] / m_gaussion_sigmab[aa][bb+1][bin_p]);
1035 if(m_dedx_chi[i]!=-99 && m_run<0){
1036 m_dedx_chi[i] = (m_dedx_chi[i] - m_gaussion_mean[aa][bb][bin_p]) / (m_gaussion_sigmab[aa][bb][bin_p] / m_gaussion_sigmab[aa][bb][bin_p]);
1045void SimplePIDSvc::loadSecondPar()
1047 string path = getenv(
"SIMPLEPIDSVCROOT");
1049 for(
int i=0; i<12; i++){
1053 if(i == 0) dir =
"round0304_dedx";
1054 else if(i == 1) dir =
"round15_dedx";
1055 else if(i == 2) dir =
"round0304_tof";
1056 else if(i == 3) dir =
"round15_tof";
1057 else if(i == 4) dir =
"round0304_tof_endcap";
1058 else if(i == 5) dir =
"round15_tof_endcap";
1060 else if(i == 6) dir =
"round16_dedx";
1061 else if(i == 7) dir =
"round16_tof";
1062 else if(i == 8) dir =
"round16_tof_endcap";
1064 else if(i == 9) dir =
"round17_dedx";
1065 else if(i == 10) dir =
"round17_tof";
1066 else if(i == 11) dir =
"round17_tof_endcap";
1069 cout <<
"Boundary Error! " << endl;
1073 for(
int j=0; j<4; j++){
1077 if(j == 0) name =
"data_K";
1078 else if(j == 1) name =
"inc_K";
1079 else if(j == 2) name =
"data_pi";
1080 else if(j == 3) name =
"inc_pi";
1082 cout <<
"Boundary Error! " << endl;
1086 ifstream second_cor( path + Form(
"/share/second_correct/%s/%s_%s.dat",dir,dir,name));
1088 for(
int m=0; m<10; m++){
1090 second_cor>>m_gaussion_mean[i][j][m]>>m_gaussion_sigma[i][j][m]>>m_gaussion_sigmab[i][j][m];
1102void SimplePIDSvc::loadHistogram()
1104 string path = getenv(
"SIMPLEPIDSVCROOT");
1105 vector<string> filename;
1106 for (
unsigned int idx = 0; idx < 2; idx++)
1115 cout <<
"Boundary Error! " << endl;
1121 filename.push_back( path + Form(
"/share/%s/dedx/dedx_d10.root", dir) );
1122 filename.push_back( path + Form(
"/share/%s/dedx/dedx_d11.root", dir) );
1123 filename.push_back( path + Form(
"/share/%s/dedx/dedx_m10.root", dir) );
1124 filename.push_back( path + Form(
"/share/%s/dedx/dedx_m11.root", dir) );
1125 for (
unsigned int i = 0; i < filename.size(); i++)
1127 f_dedx[idx][i] =
new TFile(filename[i].
c_str(),
"READ");
1139 cout <<
"Boundary Error! " << endl;
1142 h_dedx_p_offset[idx][i] = (TH2D*)f_dedx[idx][i]->Get( Form(
"h_dedx_p_offset_%s", name) );
1143 h_dedx_p_sigma[idx][i] = (TH2D*)f_dedx[idx][i]->Get( Form(
"h_dedx_p_sigma_%s" , name) );
1144 h_dedx_m_offset[idx][i] = (TH2D*)f_dedx[idx][i]->Get( Form(
"h_dedx_m_offset_%s", name) );
1145 h_dedx_m_sigma[idx][i] = (TH2D*)f_dedx[idx][i]->Get( Form(
"h_dedx_m_sigma_%s" , name) );
1149 filename.push_back( path + Form(
"/share/%s/tof_barrel/tof_q_d10.root", dir) );
1150 filename.push_back( path + Form(
"/share/%s/tof_barrel/tof_q_d11.root", dir) );
1151 filename.push_back( path + Form(
"/share/%s/tof_barrel/tof_q_m10.root", dir) );
1152 filename.push_back( path + Form(
"/share/%s/tof_barrel/tof_q_m11.root", dir) );
1153 for (
unsigned int i = 0; i < filename.size(); i++)
1155 f_tof_q[idx][i] =
new TFile(filename[i].
c_str(),
"READ");
1167 cout <<
"Boundary Error! " << endl;
1170 for (
unsigned int j = 0; j < 4; j++)
1172 h_tof_p_q_offset[idx][i][j] = (TH1D*)f_tof_q[idx][i]->Get( Form(
"h_tof_p_q_offset_%s_%d", name, j) );
1173 h_tof_m_q_offset[idx][i][j] = (TH1D*)f_tof_q[idx][i]->Get( Form(
"h_tof_m_q_offset_%s_%d", name, j) );
1174 h_tof_p_q_sigma[idx][i][j] = (TH1D*)f_tof_q[idx][i]->Get( Form(
"h_tof_p_q_sigma_%s_%d" , name, j) );
1175 h_tof_m_q_sigma[idx][i][j] = (TH1D*)f_tof_q[idx][i]->Get( Form(
"h_tof_m_q_sigma_%s_%d" , name, j) );
1180 filename.push_back( path + Form(
"/share/%s/tof_barrel/tof_bg_cost_d10.root", dir) );
1181 filename.push_back( path + Form(
"/share/%s/tof_barrel/tof_bg_cost_d11.root", dir) );
1182 filename.push_back( path + Form(
"/share/%s/tof_barrel/tof_bg_cost_m10.root", dir) );
1183 filename.push_back( path + Form(
"/share/%s/tof_barrel/tof_bg_cost_m11.root", dir) );
1184 for (
unsigned int i = 0; i < filename.size(); i++)
1186 f_tof_bgcost[idx][i] =
new TFile(filename[i].
c_str(),
"READ");
1198 cout <<
"Boundary Error! " << endl;
1201 for (
unsigned int j = 0; j < 4; j++)
1203 h_tof_p_bgcost_offset[idx][i][j] = (TH2D*)f_tof_bgcost[idx][i]->Get( Form(
"h_tof_p_bgcost_offset_%s_%d", name, j) );
1204 h_tof_m_bgcost_offset[idx][i][j] = (TH2D*)f_tof_bgcost[idx][i]->Get( Form(
"h_tof_m_bgcost_offset_%s_%d", name, j) );
1205 h_tof_p_bgcost_sigma[idx][i][j] = (TH2D*)f_tof_bgcost[idx][i]->Get( Form(
"h_tof_p_bgcost_sigma_%s_%d" , name, j) );
1206 h_tof_m_bgcost_sigma[idx][i][j] = (TH2D*)f_tof_bgcost[idx][i]->Get( Form(
"h_tof_m_bgcost_sigma_%s_%d" , name, j) );
1211 filename.push_back( path + Form(
"/share/%s/tof_barrel/tof_wgt_d10.root", dir) );
1212 filename.push_back( path + Form(
"/share/%s/tof_barrel/tof_wgt_d11.root", dir) );
1213 filename.push_back( path + Form(
"/share/%s/tof_barrel/tof_wgt_m10.root", dir) );
1214 filename.push_back( path + Form(
"/share/%s/tof_barrel/tof_wgt_m11.root", dir) );
1215 for (
unsigned int i = 0; i < filename.size(); i++)
1217 f_tof_wgt[idx][i] =
new TFile(filename[i].
c_str(),
"READ");
1229 cout <<
"Boundary Error! " << endl;
1232 for (
unsigned int j = 0; j < 15; j++)
1234 for (
unsigned int k = 0; k < 5; k++)
1236 h_tof_p_wgt[idx][i][j][k] = (TH2D*)f_tof_wgt[idx][i]->Get( Form(
"h_tof_p_wgt_%s_%d_%d", name, j, k) );
1237 h_tof_m_wgt[idx][i][j][k] = (TH2D*)f_tof_wgt[idx][i]->Get( Form(
"h_tof_m_wgt_%s_%d_%d", name, j, k) );
1243 filename.push_back( path + Form(
"/share/%s/tof_barrel/tof_final_d10.root", dir) );
1244 filename.push_back( path + Form(
"/share/%s/tof_barrel/tof_final_d11.root", dir) );
1245 filename.push_back( path + Form(
"/share/%s/tof_barrel/tof_final_m10.root", dir) );
1246 filename.push_back( path + Form(
"/share/%s/tof_barrel/tof_final_m11.root", dir) );
1247 for (
unsigned int i = 0; i < filename.size(); i++)
1249 f_tof_final[idx][i] =
new TFile(filename[i].
c_str(),
"READ");
1261 cout <<
"Boundary Error! " << endl;
1264 for (
unsigned int j = 0; j < 15; j++)
1266 h_tof_p_final_offset[idx][i][j] = (TH2D*)f_tof_final[idx][i]->Get( Form(
"h_tof_p_final_offset_%s_%d", name, j) );
1267 h_tof_m_final_offset[idx][i][j] = (TH2D*)f_tof_final[idx][i]->Get( Form(
"h_tof_m_final_offset_%s_%d", name, j) );
1268 h_tof_p_final_sigma[idx][i][j] = (TH2D*)f_tof_final[idx][i]->Get( Form(
"h_tof_p_final_sigma_%s_%d" , name, j) );
1269 h_tof_m_final_sigma[idx][i][j] = (TH2D*)f_tof_final[idx][i]->Get( Form(
"h_tof_m_final_sigma_%s_%d" , name, j) );
1274 filename.push_back( path + Form(
"/share/%s/tof_endcap/tofec_q_d10.root", dir) );
1275 filename.push_back( path + Form(
"/share/%s/tof_endcap/tofec_q_d11.root", dir) );
1276 filename.push_back( path + Form(
"/share/%s/tof_endcap/tofec_q_m10.root", dir) );
1277 filename.push_back( path + Form(
"/share/%s/tof_endcap/tofec_q_m11.root", dir) );
1278 for (
unsigned int i = 0; i < filename.size(); i++)
1280 f_tofec_q[idx][i] =
new TFile(filename[i].
c_str(),
"READ");
1292 cout <<
"Boundary Error! " << endl;
1295 for (
unsigned int j = 0; j < 2; j++)
1297 h_tofec_p_q_offset[idx][i][j] = (TH1D*)f_tofec_q[idx][i]->Get( Form(
"h_tofec_p_q_offset_%s_%d", name, j) );
1298 h_tofec_m_q_offset[idx][i][j] = (TH1D*)f_tofec_q[idx][i]->Get( Form(
"h_tofec_m_q_offset_%s_%d", name, j) );
1299 h_tofec_p_q_sigma[idx][i][j] = (TH1D*)f_tofec_q[idx][i]->Get( Form(
"h_tofec_p_q_sigma_%s_%d" , name, j) );
1300 h_tofec_m_q_sigma[idx][i][j] = (TH1D*)f_tofec_q[idx][i]->Get( Form(
"h_tofec_m_q_sigma_%s_%d" , name, j) );
1305 filename.push_back( path + Form(
"/share/%s/tof_endcap/tofec_bg_d10.root", dir) );
1306 filename.push_back( path + Form(
"/share/%s/tof_endcap/tofec_bg_d11.root", dir) );
1307 filename.push_back( path + Form(
"/share/%s/tof_endcap/tofec_bg_m10.root", dir) );
1308 filename.push_back( path + Form(
"/share/%s/tof_endcap/tofec_bg_m11.root", dir) );
1309 for (
unsigned int i = 0; i < filename.size(); i++)
1311 f_tofec_bg[idx][i] =
new TFile(filename[i].
c_str(),
"READ");
1323 cout <<
"Boundary Error! " << endl;
1326 for (
unsigned int j = 0; j < 2; j++)
1328 h_tofec_p_bg_offset[idx][i][j] = (TH1D*)f_tofec_bg[idx][i]->Get( Form(
"h_tofec_p_bg_offset_%s_%d", name, j) );
1329 h_tofec_m_bg_offset[idx][i][j] = (TH1D*)f_tofec_bg[idx][i]->Get( Form(
"h_tofec_m_bg_offset_%s_%d", name, j) );
1330 h_tofec_p_bg_sigma[idx][i][j] = (TH1D*)f_tofec_bg[idx][i]->Get( Form(
"h_tofec_p_bg_sigma_%s_%d" , name, j) );
1331 h_tofec_m_bg_sigma[idx][i][j] = (TH1D*)f_tofec_bg[idx][i]->Get( Form(
"h_tofec_m_bg_sigma_%s_%d" , name, j) );
1336 filename.push_back( path + Form(
"/share/%s/tof_endcap/tofec_cost_d10.root", dir) );
1337 filename.push_back( path + Form(
"/share/%s/tof_endcap/tofec_cost_d11.root", dir) );
1338 filename.push_back( path + Form(
"/share/%s/tof_endcap/tofec_cost_m10.root", dir) );
1339 filename.push_back( path + Form(
"/share/%s/tof_endcap/tofec_cost_m11.root", dir) );
1340 for (
unsigned int i = 0; i < filename.size(); i++)
1342 f_tofec_cost[idx][i] =
new TFile(filename[i].
c_str(),
"READ");
1354 cout <<
"Boundary Error! " << endl;
1357 for (
unsigned int j = 0; j < 2; j++)
1359 h_tofec_p_cost_offset[idx][i][j] = (TH1D*)f_tofec_cost[idx][i]->Get( Form(
"h_tofec_p_cost_offset_%s_%d", name, j) );
1360 h_tofec_m_cost_offset[idx][i][j] = (TH1D*)f_tofec_cost[idx][i]->Get( Form(
"h_tofec_m_cost_offset_%s_%d", name, j) );
1361 h_tofec_p_cost_sigma[idx][i][j] = (TH1D*)f_tofec_cost[idx][i]->Get( Form(
"h_tofec_p_cost_sigma_%s_%d" , name, j) );
1362 h_tofec_m_cost_sigma[idx][i][j] = (TH1D*)f_tofec_cost[idx][i]->Get( Form(
"h_tofec_m_cost_sigma_%s_%d" , name, j) );
1366 for (
unsigned int idx = 0; idx < 3; idx++)
1370 dir =
"electron/emc";
1372 dir =
"kpi/emc_pion";
1374 dir =
"kpi/emc_kaon";
1377 cout <<
"Boundary Error! " << endl;
1382 filename.push_back( path + Form(
"/share/%s/emc_d10.root", dir) );
1383 filename.push_back( path + Form(
"/share/%s/emc_d11.root", dir) );
1384 filename.push_back( path + Form(
"/share/%s/emc_m10.root", dir) );
1385 filename.push_back( path + Form(
"/share/%s/emc_m11.root", dir) );
1386 for (
unsigned int i = 0; i < filename.size(); i++)
1388 f_emc[idx][i] =
new TFile(filename[i].
c_str(),
"READ");
1400 cout <<
"Boundary Error! " << endl;
1403 for (
unsigned int j = 0; j < 15; j++)
1405 for (
unsigned int k = 0; k < 25; k++)
1407 h_emc_ep[idx][i][j][k] = (TH1D*)f_emc[idx][i]->Get( Form(
"h_ep_%s_%d_%d", name, j, k) );
1408 h_emc_e35[idx][i][j][k] = (TH1D*)f_emc[idx][i]->Get( Form(
"h_e35_%s_%d_%d", name, j, k) );
1413 cout <<
"Successfully Return from Loading Initializations by package SimplePIDSvc ... " << endl;
1416int SimplePIDSvc::findBin(
double *a,
int length,
double value)
1418 for (
int i = 0; i < length; i++)
1420 if (value > a[i] && value <= a[i+1])
1437 return pow(m_dedx_chi[i], 2) + pow(m_tof_chi[i], 2);
1443 for (
unsigned int i = 0; i < 5; i++)
1445 m_emc_eop[i] = -99.;
1446 m_emc_likelihood[i] = -99.;
1453 m_lh_electron = -99.;
1457 RecEmcShower* emc_trk = track->
emcShower();
1458 m_emc_e = emc_trk->
energy();
1459 for (
unsigned int i = 0; i < 5; i++)
1461 m_emc_eop[i] = m_emc_e / fabs(m_p[i]);
1463 double eseed = emc_trk->
eSeed();
1464 double e3 = emc_trk->
e3x3();
1465 double e5 = emc_trk->
e5x5();
1470 m_emc_e13 = eseed / e3;
1474 m_emc_e35 = e3 / e5;
1478bool SimplePIDSvc::calEMCLikelihood()
1480 if (m_emc_eop[0] < 0)
1483 int idx = getRunIdx(m_run);
1484 const Int_t BIN_P = 15;
1485 const Int_t BIN_COST = 25;
1486 const Int_t BIN_PID = 3;
1487 const double EPS = 1e-4;
1489 double P[BIN_PID][BIN_P + 1] = {
1490 {0.20, 0.47, 0.56, 0.65, 0.72, 0.79, 0.86, 0.92, 0.98, 1.03, 1.08, 1.13, 1.17, 1.22, 1.26, 1.30},
1491 {0.20, 0.26, 0.31, 0.35, 0.39, 0.42, 0.46, 0.49, 0.53, 0.57, 0.62, 0.67, 0.73, 0.80, 0.88, 1.05},
1492 {0.20, 0.33, 0.39, 0.43, 0.48, 0.52, 0.56, 0.61, 0.67, 0.73, 0.76, 0.81, 0.85, 0.90, 0.96, 1.05}, };
1493 double COST[BIN_PID][BIN_COST + 1] = {
1494 {-0.930, -0.910, -0.905, -0.897, -0.890, -0.881, -0.871, -0.858, -0.775, -0.732, -0.669, -0.561, -0.330, 0.199, 0.515, 0.645, 0.718, 0.766, 0.804, 0.870, 0.882, 0.891, 0.898, 0.906, 0.913, 0.930},
1495 {-0.930, -0.810, -0.728, -0.648, -0.574, -0.501, -0.431, -0.364, -0.295, -0.228, -0.161, -0.096, -0.031, 0.035, 0.100, 0.167, 0.234, 0.301, 0.370, 0.439, 0.510, 0.580, 0.655, 0.733, 0.813, 0.930},
1496 {-0.930, -0.804, -0.721, -0.643, -0.568, -0.497, -0.429, -0.362, -0.293, -0.228, -0.161, -0.096, -0.029, 0.035, 0.100, 0.166, 0.233, 0.298, 0.365, 0.432, 0.500, 0.571, 0.644, 0.722, 0.805, 0.930}, };
1500 int bin_p, bin_cost;
1501 for (
unsigned int i = 0; i < 4; i++)
1514 vcost =
max(COST[pid][0]+
EPS,
min(COST[pid][BIN_COST]-
EPS, m_cost[i]));
1515 bin_p = findBin(
P[pid], BIN_P, vp);
1516 bin_cost = findBin(COST[pid], BIN_COST, vcost);
1518 m_emc_likelihood[i] = h_emc_ep[pid][idx][bin_p][bin_cost]->Interpolate(m_emc_eop[i]) * h_emc_e35[pid][idx][bin_p][bin_cost]->Interpolate(m_emc_e35);
1520 double a = m_prob[0] > 0 ? m_prob[0] : 0;
1521 double b = m_prob[2] > 0 ? m_prob[2] : 0;
1522 double c = m_prob[3] > 0 ? m_prob[3] : 0;
1523 double sum = a * m_emc_likelihood[0] +
b * m_emc_likelihood[2] + c * m_emc_likelihood[3];
1525 if (sum > 0 && m_prob[0] > 0)
1527 m_lh_electron = m_prob[0] * m_emc_likelihood[0] / sum;
1538 if (m_prob[2] > 0.00 && m_prob[2] > m_prob[3])
1546 if (m_prob[3] > 0.00 && m_prob[3] > m_prob[2])
1575 if (m_prob[0] > 0 && m_prob[0] > m_prob[2] && m_prob[0] > m_prob[3])
1582 if (calEMCLikelihood())
1584 if (m_lh_electron > m_eid_ratio)
1591 if (m_prob[0] > 0 && m_prob[0] > m_prob[2] && m_prob[0] > m_prob[3])
double cos(const BesAngle a)
double P(RecMdcKalTrack *trk)
****INTEGER imax DOUBLE PRECISION m_pi *DOUBLE PRECISION m_amfin DOUBLE PRECISION m_Chfin DOUBLE PRECISION m_Xenph DOUBLE PRECISION m_sinw2 DOUBLE PRECISION m_GFermi DOUBLE PRECISION m_MfinMin DOUBLE PRECISION m_ta2 INTEGER m_out INTEGER m_KeyFSR INTEGER m_KeyQCD *COMMON c_Semalib $ !copy of input $ !CMS energy $ !beam mass $ !final mass $ !beam charge $ !final charge $ !smallest final mass $ !Z mass $ !Z width $ !EW mixing angle $ !Gmu Fermi $ alphaQED at q
double secondMoment() const
const Hep3Vector tof1Position() const
const Hep3Vector tof2Position() const
const double theta() const
static void setPidType(PidType pidType)
bool isMdcKalTrackValid()
SmartRefVector< RecTofTrack > tofTrack()
RecEmcShower * emcShower()
RecMdcKalTrack * mdcKalTrack()
SimplePIDSvc(const std::string &name, ISvcLocator *svcLoc)
void preparePID(EvtRecTrack *track)
virtual StatusCode initialize()
bool iselectron(bool emc=true)
virtual StatusCode finalize()
unsigned int layer() const
void setStatus(unsigned int status)