BOSS 7.0.2
BESIII Offline Software System
Loading...
Searching...
No Matches
Rhopi.cxx
Go to the documentation of this file.
1#include "GaudiKernel/MsgStream.h"
2#include "GaudiKernel/AlgFactory.h"
3#include "GaudiKernel/ISvcLocator.h"
4#include "GaudiKernel/SmartDataPtr.h"
5#include "GaudiKernel/IDataProviderSvc.h"
6#include "GaudiKernel/PropertyMgr.h"
7#include "VertexFit/IVertexDbSvc.h"
8#include "GaudiKernel/Bootstrap.h"
9#include "GaudiKernel/ISvcLocator.h"
10
11#include "EventModel/EventModel.h"
12#include "EventModel/Event.h"
13
14#include "EvtRecEvent/EvtRecEvent.h"
15#include "EvtRecEvent/EvtRecTrack.h"
16#include "DstEvent/TofHitStatus.h"
17#include "EventModel/EventHeader.h"
18
19
20
21#include "TMath.h"
22#include "GaudiKernel/INTupleSvc.h"
23#include "GaudiKernel/NTuple.h"
24#include "GaudiKernel/Bootstrap.h"
25#include "GaudiKernel/IHistogramSvc.h"
26#include "CLHEP/Vector/ThreeVector.h"
27#include "CLHEP/Vector/LorentzVector.h"
28#include "CLHEP/Vector/TwoVector.h"
29using CLHEP::Hep3Vector;
30using CLHEP::Hep2Vector;
31using CLHEP::HepLorentzVector;
32#include "CLHEP/Geometry/Point3D.h"
33#ifndef ENABLE_BACKWARDS_COMPATIBILITY
35#endif
36#include "RhopiAlg/Rhopi.h"
37
38//#include "VertexFit/KinematicFit.h"
39#include "VertexFit/KalmanKinematicFit.h"
40#include "VertexFit/VertexFit.h"
41#include "VertexFit/Helix.h"
42#include "ParticleID/ParticleID.h"
43
44#include <vector>
45//const double twopi = 6.2831853;
46//const double pi = 3.1415927;
47const double mpi = 0.13957;
48const double xmass[5] = {0.000511, 0.105658, 0.139570,0.493677, 0.938272};
49//const double velc = 29.9792458; tof_path unit in cm.
50const double velc = 299.792458; // tof path unit in mm
51typedef std::vector<int> Vint;
52typedef std::vector<HepLorentzVector> Vp4;
53
55
56/////////////////////////////////////////////////////////////////////////////
57
58Rhopi::Rhopi(const std::string& name, ISvcLocator* pSvcLocator) :
59 Algorithm(name, pSvcLocator) {
60
61 //Declare the properties
62 declareProperty("Vr0cut", m_vr0cut=1.0);
63 declareProperty("Vz0cut", m_vz0cut=5.0);
64 declareProperty("EnergyThreshold", m_energyThreshold=0.04);
65 declareProperty("GammaPhiCut", m_gammaPhiCut=20.0);
66 declareProperty("GammaThetaCut", m_gammaThetaCut=20.0);
67 declareProperty("GammaAngleCut", m_gammaAngleCut=20.0);
68 declareProperty("Test4C", m_test4C = 1);
69 declareProperty("Test5C", m_test5C = 1);
70 declareProperty("CheckDedx", m_checkDedx = 1);
71 declareProperty("CheckTof", m_checkTof = 1);
72}
73
74// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
75StatusCode Rhopi::initialize(){
76 MsgStream log(msgSvc(), name());
77
78 log << MSG::INFO << "in initialize()" << endmsg;
79
80 StatusCode status;
81 NTuplePtr nt1(ntupleSvc(), "FILE1/vxyz");
82 if ( nt1 ) m_tuple1 = nt1;
83 else {
84 m_tuple1 = ntupleSvc()->book ("FILE1/vxyz", CLID_ColumnWiseTuple, "ks N-Tuple example");
85 if ( m_tuple1 ) {
86 status = m_tuple1->addItem ("vx0", m_vx0);
87 status = m_tuple1->addItem ("vy0", m_vy0);
88 status = m_tuple1->addItem ("vz0", m_vz0);
89 status = m_tuple1->addItem ("vr0", m_vr0);
90 status = m_tuple1->addItem ("rvxy0", m_rvxy0);
91 status = m_tuple1->addItem ("rvz0", m_rvz0);
92 status = m_tuple1->addItem ("rvphi0", m_rvphi0);
93 }
94 else {
95 log << MSG::ERROR << " Cannot book N-tuple:" << long(m_tuple1) << endmsg;
96 return StatusCode::FAILURE;
97 }
98 }
99
100 NTuplePtr nt2(ntupleSvc(), "FILE1/photon");
101 if ( nt2 ) m_tuple2 = nt2;
102 else {
103 m_tuple2 = ntupleSvc()->book ("FILE1/photon", CLID_ColumnWiseTuple, "ks N-Tuple example");
104 if ( m_tuple2 ) {
105 status = m_tuple2->addItem ("dthe", m_dthe);
106 status = m_tuple2->addItem ("dphi", m_dphi);
107 status = m_tuple2->addItem ("dang", m_dang);
108 status = m_tuple2->addItem ("eraw", m_eraw);
109 }
110 else {
111 log << MSG::ERROR << " Cannot book N-tuple:" << long(m_tuple2) << endmsg;
112 return StatusCode::FAILURE;
113 }
114 }
115
116
117 NTuplePtr nt3(ntupleSvc(), "FILE1/etot");
118 if ( nt3 ) m_tuple3 = nt3;
119 else {
120 m_tuple3 = ntupleSvc()->book ("FILE1/etot", CLID_ColumnWiseTuple, "ks N-Tuple example");
121 if ( m_tuple3 ) {
122 status = m_tuple3->addItem ("m2gg", m_m2gg);
123 status = m_tuple3->addItem ("etot", m_etot);
124 }
125 else {
126 log << MSG::ERROR << " Cannot book N-tuple:" << long(m_tuple3) << endmsg;
127 return StatusCode::FAILURE;
128 }
129 }
130 if(m_test4C==1) {
131 NTuplePtr nt4(ntupleSvc(), "FILE1/fit4c");
132 if ( nt4 ) m_tuple4 = nt4;
133 else {
134 m_tuple4 = ntupleSvc()->book ("FILE1/fit4c", CLID_ColumnWiseTuple, "ks N-Tuple example");
135 if ( m_tuple4 ) {
136 status = m_tuple4->addItem ("chi2", m_chi1);
137 status = m_tuple4->addItem ("mpi0", m_mpi0);
138 }
139 else {
140 log << MSG::ERROR << " Cannot book N-tuple:" << long(m_tuple4) << endmsg;
141 return StatusCode::FAILURE;
142 }
143 }
144 } // test 4C
145
146
147 if(m_test5C==1) {
148 NTuplePtr nt5(ntupleSvc(), "FILE1/fit5c");
149 if ( nt5 ) m_tuple5 = nt5;
150 else {
151 m_tuple5 = ntupleSvc()->book ("FILE1/fit5c", CLID_ColumnWiseTuple, "ks N-Tuple example");
152 if ( m_tuple5 ) {
153 status = m_tuple5->addItem ("chi2", m_chi2);
154 status = m_tuple5->addItem ("mrh0", m_mrh0);
155 status = m_tuple5->addItem ("mrhp", m_mrhp);
156 status = m_tuple5->addItem ("mrhm", m_mrhm);
157 }
158 else {
159 log << MSG::ERROR << " Cannot book N-tuple:" << long(m_tuple5) << endmsg;
160 return StatusCode::FAILURE;
161 }
162 }
163
164 NTuplePtr nt6(ntupleSvc(), "FILE1/geff");
165 if ( nt6 ) m_tuple6 = nt6;
166 else {
167 m_tuple6 = ntupleSvc()->book ("FILE1/geff", CLID_ColumnWiseTuple, "ks N-Tuple example");
168 if ( m_tuple6 ) {
169 status = m_tuple6->addItem ("fcos", m_fcos);
170 status = m_tuple6->addItem ("elow", m_elow);
171 }
172 else {
173 log << MSG::ERROR << " Cannot book N-tuple:" << long(m_tuple6) << endmsg;
174 return StatusCode::FAILURE;
175 }
176 }
177 } // test 5c
178
179 if(m_checkDedx == 1) {
180 NTuplePtr nt7(ntupleSvc(), "FILE1/dedx");
181 if ( nt7 ) m_tuple7 = nt7;
182 else {
183 m_tuple7 = ntupleSvc()->book ("FILE1/dedx", CLID_ColumnWiseTuple, "ks N-Tuple example");
184 if ( m_tuple7 ) {
185 status = m_tuple7->addItem ("ptrk", m_ptrk);
186 status = m_tuple7->addItem ("chie", m_chie);
187 status = m_tuple7->addItem ("chimu", m_chimu);
188 status = m_tuple7->addItem ("chipi", m_chipi);
189 status = m_tuple7->addItem ("chik", m_chik);
190 status = m_tuple7->addItem ("chip", m_chip);
191 status = m_tuple7->addItem ("probPH", m_probPH);
192 status = m_tuple7->addItem ("normPH", m_normPH);
193 status = m_tuple7->addItem ("ghit", m_ghit);
194 status = m_tuple7->addItem ("thit", m_thit);
195 }
196 else {
197 log << MSG::ERROR << " Cannot book N-tuple:" << long(m_tuple7) << endmsg;
198 return StatusCode::FAILURE;
199 }
200 }
201 } // check dE/dx
202
203 if(m_checkTof == 1) {
204 NTuplePtr nt8(ntupleSvc(), "FILE1/tofe");
205 if ( nt8 ) m_tuple8 = nt8;
206 else {
207 m_tuple8 = ntupleSvc()->book ("FILE1/tofe",CLID_ColumnWiseTuple, "ks N-Tuple example");
208 if ( m_tuple8 ) {
209 status = m_tuple8->addItem ("ptrk", m_ptot_etof);
210 status = m_tuple8->addItem ("cntr", m_cntr_etof);
211 status = m_tuple8->addItem ("ph", m_ph_etof);
212 status = m_tuple8->addItem ("rhit", m_rhit_etof);
213 status = m_tuple8->addItem ("qual", m_qual_etof);
214 status = m_tuple8->addItem ("te", m_te_etof);
215 status = m_tuple8->addItem ("tmu", m_tmu_etof);
216 status = m_tuple8->addItem ("tpi", m_tpi_etof);
217 status = m_tuple8->addItem ("tk", m_tk_etof);
218 status = m_tuple8->addItem ("tp", m_tp_etof);
219 }
220 else {
221 log << MSG::ERROR << " Cannot book N-tuple:" << long(m_tuple8) << endmsg;
222 return StatusCode::FAILURE;
223 }
224 }
225 } // check Tof:endcap
226
227
228
229 if(m_checkTof == 1) {
230 NTuplePtr nt9(ntupleSvc(), "FILE1/tof1");
231 if ( nt9 ) m_tuple9 = nt9;
232 else {
233 m_tuple9 = ntupleSvc()->book ("FILE1/tof1", CLID_ColumnWiseTuple, "ks N-Tuple example");
234 if ( m_tuple9 ) {
235 status = m_tuple9->addItem ("ptrk", m_ptot_btof1);
236 status = m_tuple9->addItem ("cntr", m_cntr_btof1);
237 status = m_tuple9->addItem ("ph", m_ph_btof1);
238 status = m_tuple9->addItem ("zhit", m_zhit_btof1);
239 status = m_tuple9->addItem ("qual", m_qual_btof1);
240 status = m_tuple9->addItem ("te", m_te_btof1);
241 status = m_tuple9->addItem ("tmu", m_tmu_btof1);
242 status = m_tuple9->addItem ("tpi", m_tpi_btof1);
243 status = m_tuple9->addItem ("tk", m_tk_btof1);
244 status = m_tuple9->addItem ("tp", m_tp_btof1);
245 }
246 else {
247 log << MSG::ERROR << " Cannot book N-tuple:" << long(m_tuple9) << endmsg;
248 return StatusCode::FAILURE;
249 }
250 }
251 } // check Tof:barrel inner Tof
252
253
254 if(m_checkTof == 1) {
255 NTuplePtr nt10(ntupleSvc(), "FILE1/tof2");
256 if ( nt10 ) m_tuple10 = nt10;
257 else {
258 m_tuple10 = ntupleSvc()->book ("FILE1/tof2", CLID_ColumnWiseTuple, "ks N-Tuple example");
259 if ( m_tuple10 ) {
260 status = m_tuple10->addItem ("ptrk", m_ptot_btof2);
261 status = m_tuple10->addItem ("cntr", m_cntr_btof2);
262 status = m_tuple10->addItem ("ph", m_ph_btof2);
263 status = m_tuple10->addItem ("zhit", m_zhit_btof2);
264 status = m_tuple10->addItem ("qual", m_qual_btof2);
265 status = m_tuple10->addItem ("te", m_te_btof2);
266 status = m_tuple10->addItem ("tmu", m_tmu_btof2);
267 status = m_tuple10->addItem ("tpi", m_tpi_btof2);
268 status = m_tuple10->addItem ("tk", m_tk_btof2);
269 status = m_tuple10->addItem ("tp", m_tp_btof2);
270 }
271 else {
272 log << MSG::ERROR << " Cannot book N-tuple:" << long(m_tuple10) << endmsg;
273 return StatusCode::FAILURE;
274 }
275 }
276 } // check Tof:barrel outter Tof
277
278
279 NTuplePtr nt11(ntupleSvc(), "FILE1/pid");
280 if ( nt11 ) m_tuple11 = nt11;
281 else {
282 m_tuple11 = ntupleSvc()->book ("FILE1/pid", CLID_ColumnWiseTuple, "ks N-Tuple example");
283 if ( m_tuple11 ) {
284 status = m_tuple11->addItem ("ptrk", m_ptrk_pid);
285 status = m_tuple11->addItem ("cost", m_cost_pid);
286 status = m_tuple11->addItem ("dedx", m_dedx_pid);
287 status = m_tuple11->addItem ("tof1", m_tof1_pid);
288 status = m_tuple11->addItem ("tof2", m_tof2_pid);
289 status = m_tuple11->addItem ("prob", m_prob_pid);
290 }
291 else {
292 log << MSG::ERROR << " Cannot book N-tuple:" << long(m_tuple11) << endmsg;
293 return StatusCode::FAILURE;
294 }
295 }
296
297
298 //
299 //--------end of book--------
300 //
301
302 log << MSG::INFO << "successfully return from initialize()" <<endmsg;
303 return StatusCode::SUCCESS;
304
305}
306
307// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
308StatusCode Rhopi::execute() {
309
310 std::cout << "execute()" << std::endl;
311
312 MsgStream log(msgSvc(), name());
313 log << MSG::INFO << "in execute()" << endreq;
314
315 SmartDataPtr<Event::EventHeader> eventHeader(eventSvc(),"/Event/EventHeader");
316 int runNo=eventHeader->runNumber();
317 int event=eventHeader->eventNumber();
318 log << MSG::DEBUG <<"run, evtnum = "
319 << runNo << " , "
320 << event <<endreq;
321 cout<<"event "<<event<<endl;
322 Ncut0++;
323
324 SmartDataPtr<EvtRecEvent> evtRecEvent(eventSvc(), EventModel::EvtRec::EvtRecEvent);
325 // log << MSG::INFO << "get event tag OK" << endreq;
326 log << MSG::DEBUG <<"ncharg, nneu, tottks = "
327 << evtRecEvent->totalCharged() << " , "
328 << evtRecEvent->totalNeutral() << " , "
329 << evtRecEvent->totalTracks() <<endreq;
330
331 SmartDataPtr<EvtRecTrackCol> evtRecTrkCol(eventSvc(), EventModel::EvtRec::EvtRecTrackCol);
332 //
333 // check x0, y0, z0, r0
334 // suggest cut: |z0|<5 && r0<1
335 //
336 Vint iGood, ipip, ipim;
337 iGood.clear();
338 ipip.clear();
339 ipim.clear();
340 Vp4 ppip, ppim;
341 ppip.clear();
342 ppim.clear();
343
344 int nCharge = 0;
345
346 Hep3Vector xorigin(0,0,0);
347
348 //if (m_reader.isRunNumberValid(runNo)) {
349 IVertexDbSvc* vtxsvc;
350 Gaudi::svcLocator()->service("VertexDbSvc", vtxsvc);
351 if(vtxsvc->isVertexValid()){
352 double* dbv = vtxsvc->PrimaryVertex();
353 double* vv = vtxsvc->SigmaPrimaryVertex();
354// HepVector dbv = m_reader.PrimaryVertex(runNo);
355// HepVector vv = m_reader.SigmaPrimaryVertex(runNo);
356 xorigin.setX(dbv[0]);
357 xorigin.setY(dbv[1]);
358 xorigin.setZ(dbv[2]);
359 }
360
361 for(int i = 0; i < evtRecEvent->totalCharged(); i++){
362 EvtRecTrackIterator itTrk=evtRecTrkCol->begin() + i;
363 if(!(*itTrk)->isMdcTrackValid()) continue;
364 RecMdcTrack *mdcTrk = (*itTrk)->mdcTrack();
365 double pch=mdcTrk->p();
366 double x0=mdcTrk->x();
367 double y0=mdcTrk->y();
368 double z0=mdcTrk->z();
369 double phi0=mdcTrk->helix(1);
370 double xv=xorigin.x();
371 double yv=xorigin.y();
372 double Rxy=(x0-xv)*cos(phi0)+(y0-yv)*sin(phi0);
373 m_vx0 = x0;
374 m_vy0 = y0;
375 m_vz0 = z0;
376 m_vr0 = Rxy;
377
378 HepVector a = mdcTrk->helix();
379 HepSymMatrix Ea = mdcTrk->err();
380 HepPoint3D point0(0.,0.,0.); // the initial point for MDC recosntruction
381 HepPoint3D IP(xorigin[0],xorigin[1],xorigin[2]);
382 VFHelix helixip(point0,a,Ea);
383 helixip.pivot(IP);
384 HepVector vecipa = helixip.a();
385 double Rvxy0=fabs(vecipa[0]); //the nearest distance to IP in xy plane
386 double Rvz0=vecipa[3]; //the nearest distance to IP in z direction
387 double Rvphi0=vecipa[1];
388 m_rvxy0=Rvxy0;
389 m_rvz0=Rvz0;
390 m_rvphi0=Rvphi0;
391
392 m_tuple1->write();
393// if(fabs(z0) >= m_vz0cut) continue;
394// if(fabs(Rxy) >= m_vr0cut) continue;
395
396 if(fabs(Rvz0) >= 10.0) continue;
397 if(fabs(Rvxy0) >= 1.0) continue;
398
399 iGood.push_back(i);
400 nCharge += mdcTrk->charge();
401 }
402
403 //
404 // Finish Good Charged Track Selection
405 //
406 int nGood = iGood.size();
407 log << MSG::DEBUG << "ngood, totcharge = " << nGood << " , " << nCharge << endreq;
408 if((nGood != 2)||(nCharge!=0)){
409 return StatusCode::SUCCESS;
410 }
411 Ncut1++;
412
413 Vint iGam;
414 iGam.clear();
415 for(int i = evtRecEvent->totalCharged(); i< evtRecEvent->totalTracks(); i++) {
416 EvtRecTrackIterator itTrk=evtRecTrkCol->begin() + i;
417 if(!(*itTrk)->isEmcShowerValid()) continue;
418 RecEmcShower *emcTrk = (*itTrk)->emcShower();
419 Hep3Vector emcpos(emcTrk->x(), emcTrk->y(), emcTrk->z());
420 // find the nearest charged track
421 double dthe = 200.;
422 double dphi = 200.;
423 double dang = 200.;
424 for(int j = 0; j < evtRecEvent->totalCharged(); j++) {
425 EvtRecTrackIterator jtTrk = evtRecTrkCol->begin() + j;
426 if(!(*jtTrk)->isExtTrackValid()) continue;
427 RecExtTrack *extTrk = (*jtTrk)->extTrack();
428 if(extTrk->emcVolumeNumber() == -1) continue;
429 Hep3Vector extpos = extTrk->emcPosition();
430 // double ctht = extpos.cosTheta(emcpos);
431 double angd = extpos.angle(emcpos);
432 double thed = extpos.theta() - emcpos.theta();
433 double phid = extpos.deltaPhi(emcpos);
434 thed = fmod(thed+CLHEP::twopi+CLHEP::twopi+pi, CLHEP::twopi) - CLHEP::pi;
435 phid = fmod(phid+CLHEP::twopi+CLHEP::twopi+pi, CLHEP::twopi) - CLHEP::pi;
436 if(angd < dang){
437 dang = angd;
438 dthe = thed;
439 dphi = phid;
440 }
441 }
442 if(dang>=200) continue;
443 double eraw = emcTrk->energy();
444 dthe = dthe * 180 / (CLHEP::pi);
445 dphi = dphi * 180 / (CLHEP::pi);
446 dang = dang * 180 / (CLHEP::pi);
447 m_dthe = dthe;
448 m_dphi = dphi;
449 m_dang = dang;
450 m_eraw = eraw;
451 m_tuple2->write();
452 if(eraw < m_energyThreshold) continue;
453// if((fabs(dthe) < m_gammaThetaCut) && (fabs(dphi)<m_gammaPhiCut) ) continue;
454 if(fabs(dang) < m_gammaAngleCut) continue;
455 //
456 // good photon cut will be set here
457 //
458 iGam.push_back(i);
459 }
460
461 //
462 // Finish Good Photon Selection
463 //
464 int nGam = iGam.size();
465
466 log << MSG::DEBUG << "num Good Photon " << nGam << " , " <<evtRecEvent->totalNeutral()<<endreq;
467 if(nGam<2){
468 return StatusCode::SUCCESS;
469 }
470 Ncut2++;
471
472
473
474 //
475 //
476 // check dedx infomation
477 //
478 //
479
480 if(m_checkDedx == 1) {
481 for(int i = 0; i < nGood; i++) {
482 EvtRecTrackIterator itTrk = evtRecTrkCol->begin() + iGood[i];
483 if(!(*itTrk)->isMdcTrackValid()) continue;
484 if(!(*itTrk)->isMdcDedxValid())continue;
485 RecMdcTrack* mdcTrk = (*itTrk)->mdcTrack();
486 RecMdcDedx* dedxTrk = (*itTrk)->mdcDedx();
487 m_ptrk = mdcTrk->p();
488
489 m_chie = dedxTrk->chiE();
490 m_chimu = dedxTrk->chiMu();
491 m_chipi = dedxTrk->chiPi();
492 m_chik = dedxTrk->chiK();
493 m_chip = dedxTrk->chiP();
494 m_ghit = dedxTrk->numGoodHits();
495 m_thit = dedxTrk->numTotalHits();
496 m_probPH = dedxTrk->probPH();
497 m_normPH = dedxTrk->normPH();
498 m_tuple7->write();
499 }
500 }
501
502 //
503 // check TOF infomation
504 //
505
506
507 if(m_checkTof == 1) {
508 for(int i = 0; i < nGood; i++) {
509 EvtRecTrackIterator itTrk = evtRecTrkCol->begin() + iGood[i];
510 if(!(*itTrk)->isMdcTrackValid()) continue;
511 if(!(*itTrk)->isTofTrackValid()) continue;
512
513 RecMdcTrack * mdcTrk = (*itTrk)->mdcTrack();
514 SmartRefVector<RecTofTrack> tofTrkCol = (*itTrk)->tofTrack();
515
516 double ptrk = mdcTrk->p();
517
518 SmartRefVector<RecTofTrack>::iterator iter_tof = tofTrkCol.begin();
519 for(;iter_tof != tofTrkCol.end(); iter_tof++ ) {
520 TofHitStatus *status = new TofHitStatus;
521 status->setStatus((*iter_tof)->status());
522 if(!(status->is_barrel())){//endcap
523 if( !(status->is_counter()) ) continue; // ?
524 if( status->layer()!=0 ) continue;//layer1
525 double path=(*iter_tof)->path(); // ?
526 double tof = (*iter_tof)->tof();
527 double ph = (*iter_tof)->ph();
528 double rhit = (*iter_tof)->zrhit();
529 double qual = 0.0 + (*iter_tof)->quality();
530 double cntr = 0.0 + (*iter_tof)->tofID();
531 double texp[5];
532 for(int j = 0; j < 5; j++) {
533 double gb = ptrk/xmass[j];
534 double beta = gb/sqrt(1+gb*gb);
535 texp[j] = 10 * path /beta/velc;
536 }
537 m_cntr_etof = cntr;
538 m_ptot_etof = ptrk;
539 m_ph_etof = ph;
540 m_rhit_etof = rhit;
541 m_qual_etof = qual;
542 m_te_etof = tof - texp[0];
543 m_tmu_etof = tof - texp[1];
544 m_tpi_etof = tof - texp[2];
545 m_tk_etof = tof - texp[3];
546 m_tp_etof = tof - texp[4];
547 m_tuple8->write();
548 }
549 else {//barrel
550 if( !(status->is_counter()) ) continue; // ?
551 if(status->layer()==1){ //layer1
552 double path=(*iter_tof)->path(); // ?
553 double tof = (*iter_tof)->tof();
554 double ph = (*iter_tof)->ph();
555 double rhit = (*iter_tof)->zrhit();
556 double qual = 0.0 + (*iter_tof)->quality();
557 double cntr = 0.0 + (*iter_tof)->tofID();
558 double texp[5];
559 for(int j = 0; j < 5; j++) {
560 double gb = ptrk/xmass[j];
561 double beta = gb/sqrt(1+gb*gb);
562 texp[j] = 10 * path /beta/velc;
563 }
564
565 m_cntr_btof1 = cntr;
566 m_ptot_btof1 = ptrk;
567 m_ph_btof1 = ph;
568 m_zhit_btof1 = rhit;
569 m_qual_btof1 = qual;
570 m_te_btof1 = tof - texp[0];
571 m_tmu_btof1 = tof - texp[1];
572 m_tpi_btof1 = tof - texp[2];
573 m_tk_btof1 = tof - texp[3];
574 m_tp_btof1 = tof - texp[4];
575 m_tuple9->write();
576 }
577
578 if(status->layer()==2){//layer2
579 double path=(*iter_tof)->path(); // ?
580 double tof = (*iter_tof)->tof();
581 double ph = (*iter_tof)->ph();
582 double rhit = (*iter_tof)->zrhit();
583 double qual = 0.0 + (*iter_tof)->quality();
584 double cntr = 0.0 + (*iter_tof)->tofID();
585 double texp[5];
586 for(int j = 0; j < 5; j++) {
587 double gb = ptrk/xmass[j];
588 double beta = gb/sqrt(1+gb*gb);
589 texp[j] = 10 * path /beta/velc;
590 }
591
592 m_cntr_btof2 = cntr;
593 m_ptot_btof2 = ptrk;
594 m_ph_btof2 = ph;
595 m_zhit_btof2 = rhit;
596 m_qual_btof2 = qual;
597 m_te_btof2 = tof - texp[0];
598 m_tmu_btof2 = tof - texp[1];
599 m_tpi_btof2 = tof - texp[2];
600 m_tk_btof2 = tof - texp[3];
601 m_tp_btof2 = tof - texp[4];
602 m_tuple10->write();
603 }
604 }
605
606 delete status;
607 }
608 } // loop all charged track
609 } // check tof
610
611
612 //
613 // Assign 4-momentum to each photon
614 //
615
616 Vp4 pGam;
617 pGam.clear();
618 for(int i = 0; i < nGam; i++) {
619 EvtRecTrackIterator itTrk = evtRecTrkCol->begin() + iGam[i];
620 RecEmcShower* emcTrk = (*itTrk)->emcShower();
621 double eraw = emcTrk->energy();
622 double phi = emcTrk->phi();
623 double the = emcTrk->theta();
624 HepLorentzVector ptrk;
625 ptrk.setPx(eraw*sin(the)*cos(phi));
626 ptrk.setPy(eraw*sin(the)*sin(phi));
627 ptrk.setPz(eraw*cos(the));
628 ptrk.setE(eraw);
629
630// ptrk = ptrk.boost(-0.011,0,0);// boost to cms
631
632 pGam.push_back(ptrk);
633 }
634 cout<<"before pid"<<endl;
635 //
636 // Assign 4-momentum to each charged track
637 //
639 for(int i = 0; i < nGood; i++) {
640 EvtRecTrackIterator itTrk = evtRecTrkCol->begin() + iGood[i];
641 // if(pid) delete pid;
642 pid->init();
643 pid->setMethod(pid->methodProbability());
644// pid->setMethod(pid->methodLikelihood()); //for Likelihood Method
645
646 pid->setChiMinCut(4);
647 pid->setRecTrack(*itTrk);
648 pid->usePidSys(pid->useDedx() | pid->useTof1() | pid->useTof2() | pid->useTofE()); // use PID sub-system
649 pid->identify(pid->onlyPion() | pid->onlyKaon()); // seperater Pion/Kaon
650 // pid->identify(pid->onlyPion());
651 // pid->identify(pid->onlyKaon());
652 pid->calculate();
653 if(!(pid->IsPidInfoValid())) continue;
654 RecMdcTrack* mdcTrk = (*itTrk)->mdcTrack();
655 m_ptrk_pid = mdcTrk->p();
656 m_cost_pid = cos(mdcTrk->theta());
657 m_dedx_pid = pid->chiDedx(2);
658 m_tof1_pid = pid->chiTof1(2);
659 m_tof2_pid = pid->chiTof2(2);
660 m_prob_pid = pid->probPion();
661 m_tuple11->write();
662
663// if(pid->probPion() < 0.001 || (pid->probPion() < pid->probKaon())) continue;
664 if(pid->probPion() < 0.001) continue;
665// if(pid->pdf(2)<pid->pdf(3)) continue; // for Likelihood Method(0=electron 1=muon 2=pion 3=kaon 4=proton)
666
667 RecMdcKalTrack* mdcKalTrk = (*itTrk)->mdcKalTrack();//After ParticleID, use RecMdcKalTrack substitute RecMdcTrack
668 RecMdcKalTrack::setPidType (RecMdcKalTrack::pion);//PID can set to electron, muon, pion, kaon and proton;The default setting is pion
669
670 if(mdcKalTrk->charge() >0) {
671 ipip.push_back(iGood[i]);
672 HepLorentzVector ptrk;
673 ptrk.setPx(mdcKalTrk->px());
674 ptrk.setPy(mdcKalTrk->py());
675 ptrk.setPz(mdcKalTrk->pz());
676 double p3 = ptrk.mag();
677 ptrk.setE(sqrt(p3*p3+mpi*mpi));
678
679// ptrk = ptrk.boost(-0.011,0,0);//boost to cms
680
681 ppip.push_back(ptrk);
682 } else {
683 ipim.push_back(iGood[i]);
684 HepLorentzVector ptrk;
685 ptrk.setPx(mdcKalTrk->px());
686 ptrk.setPy(mdcKalTrk->py());
687 ptrk.setPz(mdcKalTrk->pz());
688 double p3 = ptrk.mag();
689 ptrk.setE(sqrt(p3*p3+mpi*mpi));
690
691// ptrk = ptrk.boost(-0.011,0,0);//boost to cms
692
693 ppim.push_back(ptrk);
694 }
695 }
696
697/*
698 for(int i = 0; i < nGood; i++) {//for rhopi without PID
699 EvtRecTrackIterator itTrk = evtRecTrkCol->begin() + iGood[i];
700 RecMdcTrack* mdcTrk = (*itTrk)->mdcTrack();
701 if(mdcTrk->charge() >0) {
702 ipip.push_back(iGood[i]);
703 HepLorentzVector ptrk;
704 ptrk.setPx(mdcTrk->px());
705 ptrk.setPy(mdcTrk->py());
706 ptrk.setPz(mdcTrk->pz());
707 double p3 = ptrk.mag();
708 ptrk.setE(sqrt(p3*p3+mpi*mpi));
709 ppip.push_back(ptrk);
710 } else {
711 ipim.push_back(iGood[i]);
712 HepLorentzVector ptrk;
713 ptrk.setPx(mdcTrk->px());
714 ptrk.setPy(mdcTrk->py());
715 ptrk.setPz(mdcTrk->pz());
716 double p3 = ptrk.mag();
717 ptrk.setE(sqrt(p3*p3+mpi*mpi));
718 ppim.push_back(ptrk);
719 }
720 }// without PID
721*/
722
723 int npip = ipip.size();
724 int npim = ipim.size();
725 if(npip*npim != 1) return SUCCESS;
726
727 Ncut3++;
728
729
730 //
731 // Loop each gamma pair, check ppi0 and pTot
732 //
733
734 HepLorentzVector pTot;
735 for(int i = 0; i < nGam - 1; i++){
736 for(int j = i+1; j < nGam; j++) {
737 HepLorentzVector p2g = pGam[i] + pGam[j];
738 pTot = ppip[0] + ppim[0];
739 pTot += p2g;
740 m_m2gg = p2g.m();
741 m_etot = pTot.e();
742 m_tuple3 -> write();
743
744 }
745 }
746
747
748 RecMdcKalTrack *pipTrk = (*(evtRecTrkCol->begin()+ipip[0]))->mdcKalTrack();
749 RecMdcKalTrack *pimTrk = (*(evtRecTrkCol->begin()+ipim[0]))->mdcKalTrack();
750
751 WTrackParameter wvpipTrk, wvpimTrk;
752 wvpipTrk = WTrackParameter(mpi, pipTrk->getZHelix(), pipTrk->getZError());
753 wvpimTrk = WTrackParameter(mpi, pimTrk->getZHelix(), pimTrk->getZError());
754
755/* Default is pion, for other particles:
756 wvppTrk = WTrackParameter(mp, pipTrk->getZHelixP(), pipTrk->getZErrorP());//proton
757 wvmupTrk = WTrackParameter(mmu, pipTrk->getZHelixMu(), pipTrk->getZErrorMu());//muon
758 wvepTrk = WTrackParameter(me, pipTrk->getZHelixE(), pipTrk->getZErrorE());//electron
759 wvkpTrk = WTrackParameter(mk, pipTrk->getZHelixK(), pipTrk->getZErrorK());//kaon
760*/
761 //
762 // Test vertex fit
763 //
764
765 HepPoint3D vx(0., 0., 0.);
766 HepSymMatrix Evx(3, 0);
767 double bx = 1E+6;
768 double by = 1E+6;
769 double bz = 1E+6;
770 Evx[0][0] = bx*bx;
771 Evx[1][1] = by*by;
772 Evx[2][2] = bz*bz;
773
774 VertexParameter vxpar;
775 vxpar.setVx(vx);
776 vxpar.setEvx(Evx);
777
778 VertexFit* vtxfit = VertexFit::instance();
779 vtxfit->init();
780 vtxfit->AddTrack(0, wvpipTrk);
781 vtxfit->AddTrack(1, wvpimTrk);
782 vtxfit->AddVertex(0, vxpar,0, 1);
783 if(!vtxfit->Fit(0)) return SUCCESS;
784 vtxfit->Swim(0);
785
786 WTrackParameter wpip = vtxfit->wtrk(0);
787 WTrackParameter wpim = vtxfit->wtrk(1);
788
789 //KinematicFit * kmfit = KinematicFit::instance();
791
792 //
793 // Apply Kinematic 4C fit
794 //
795 cout<<"before 4c"<<endl;
796 if(m_test4C==1) {
797// double ecms = 3.097;
798 HepLorentzVector ecms(0.034,0,0,3.097);
799
800 double chisq = 9999.;
801 int ig1 = -1;
802 int ig2 = -1;
803 for(int i = 0; i < nGam-1; i++) {
804 RecEmcShower *g1Trk = (*(evtRecTrkCol->begin()+iGam[i]))->emcShower();
805 for(int j = i+1; j < nGam; j++) {
806 RecEmcShower *g2Trk = (*(evtRecTrkCol->begin()+iGam[j]))->emcShower();
807 kmfit->init();
808 kmfit->AddTrack(0, wpip);
809 kmfit->AddTrack(1, wpim);
810 kmfit->AddTrack(2, 0.0, g1Trk);
811 kmfit->AddTrack(3, 0.0, g2Trk);
812 kmfit->AddFourMomentum(0, ecms);
813 bool oksq = kmfit->Fit();
814 if(oksq) {
815 double chi2 = kmfit->chisq();
816 if(chi2 < chisq) {
817 chisq = chi2;
818 ig1 = iGam[i];
819 ig2 = iGam[j];
820 }
821 }
822 }
823 }
824
825 if(chisq < 200) {
826
827 RecEmcShower *g1Trk = (*(evtRecTrkCol->begin()+ig1))->emcShower();
828 RecEmcShower *g2Trk = (*(evtRecTrkCol->begin()+ig2))->emcShower();
829 kmfit->init();
830 kmfit->AddTrack(0, wpip);
831 kmfit->AddTrack(1, wpim);
832 kmfit->AddTrack(2, 0.0, g1Trk);
833 kmfit->AddTrack(3, 0.0, g2Trk);
834 kmfit->AddFourMomentum(0, ecms);
835 bool oksq = kmfit->Fit();
836 if(oksq) {
837 HepLorentzVector ppi0 = kmfit->pfit(2) + kmfit->pfit(3);
838 m_mpi0 = ppi0.m();
839 m_chi1 = kmfit->chisq();
840 m_tuple4->write();
841 Ncut4++;
842 }
843 }
844 }
845
846 //
847 // Apply Kinematic 5C Fit
848 //
849
850 // find the best combination over all possible pi+ pi- gamma gamma pair
851 if(m_test5C==1) {
852// double ecms = 3.097;
853 HepLorentzVector ecms(0.034,0,0,3.097);
854 double chisq = 9999.;
855 int ig1 = -1;
856 int ig2 = -1;
857 for(int i = 0; i < nGam-1; i++) {
858 RecEmcShower *g1Trk = (*(evtRecTrkCol->begin()+iGam[i]))->emcShower();
859 for(int j = i+1; j < nGam; j++) {
860 RecEmcShower *g2Trk = (*(evtRecTrkCol->begin()+iGam[j]))->emcShower();
861 kmfit->init();
862 kmfit->AddTrack(0, wpip);
863 kmfit->AddTrack(1, wpim);
864 kmfit->AddTrack(2, 0.0, g1Trk);
865 kmfit->AddTrack(3, 0.0, g2Trk);
866 kmfit->AddResonance(0, 0.135, 2, 3);
867 kmfit->AddFourMomentum(1, ecms);
868 if(!kmfit->Fit(0)) continue;
869 if(!kmfit->Fit(1)) continue;
870 bool oksq = kmfit->Fit();
871 if(oksq) {
872 double chi2 = kmfit->chisq();
873 if(chi2 < chisq) {
874 chisq = chi2;
875 ig1 = iGam[i];
876 ig2 = iGam[j];
877 }
878 }
879 }
880 }
881
882
883 log << MSG::INFO << " chisq = " << chisq <<endreq;
884
885 if(chisq < 200) {
886 RecEmcShower* g1Trk = (*(evtRecTrkCol->begin()+ig1))->emcShower();
887 RecEmcShower* g2Trk = (*(evtRecTrkCol->begin()+ig2))->emcShower();
888
889 kmfit->init();
890 kmfit->AddTrack(0, wpip);
891 kmfit->AddTrack(1, wpim);
892 kmfit->AddTrack(2, 0.0, g1Trk);
893 kmfit->AddTrack(3, 0.0, g2Trk);
894 kmfit->AddResonance(0, 0.135, 2, 3);
895 kmfit->AddFourMomentum(1, ecms);
896 bool oksq = kmfit->Fit();
897 if(oksq){
898 HepLorentzVector ppi0 = kmfit->pfit(2) + kmfit->pfit(3);
899 HepLorentzVector prho0 = kmfit->pfit(0) + kmfit->pfit(1);
900 HepLorentzVector prhop = ppi0 + kmfit->pfit(0);
901 HepLorentzVector prhom = ppi0 + kmfit->pfit(1);
902
903 m_chi2 = kmfit->chisq();
904 m_mrh0 = prho0.m();
905 m_mrhp = prhop.m();
906 m_mrhm = prhom.m();
907 double eg1 = (kmfit->pfit(2)).e();
908 double eg2 = (kmfit->pfit(3)).e();
909 double fcos = abs(eg1-eg2)/ppi0.rho();
910 m_tuple5->write();
911 Ncut5++;
912 //
913 // Measure the photon detection efficiences via
914 // J/psi -> rho0 pi0
915 //
916 if(fabs(prho0.m()-0.770)<0.150) {
917 if(fabs(fcos)<0.99) {
918 m_fcos = (eg1-eg2)/ppi0.rho();
919 m_elow = (eg1 < eg2) ? eg1 : eg2;
920 m_tuple6->write();
921 Ncut6++;
922 }
923 } // rho0 cut
924 } //oksq
925 }
926 }
927 return StatusCode::SUCCESS;
928}
929
930
931// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
932StatusCode Rhopi::finalize() {
933 cout<<"total number: "<<Ncut0<<endl;
934 cout<<"nGood==2, nCharge==0: "<<Ncut1<<endl;
935 cout<<"nGam>=2: "<<Ncut2<<endl;
936 cout<<"Pass Pid: "<<Ncut3<<endl;
937 cout<<"Pass 4C: "<<Ncut4<<endl;
938 cout<<"Pass 5C: "<<Ncut5<<endl;
939 cout<<"J/psi->rho0 pi0: "<<Ncut6<<endl;
940 MsgStream log(msgSvc(), name());
941 log << MSG::INFO << "in finalize()" << endmsg;
942 return StatusCode::SUCCESS;
943}
944
int runNo
Definition: DQA_TO_DB.cxx:12
std::vector< HepLorentzVector > Vp4
Definition: Gam4pikp.cxx:53
const double xmass[5]
Definition: Gam4pikp.cxx:50
const double velc
Definition: Gam4pikp.cxx:51
const double mpi
Definition: Gam4pikp.cxx:47
std::vector< int > Vint
Definition: Gam4pikp.cxx:52
double sin(const BesAngle a)
double cos(const BesAngle a)
int Ncut2
Definition: Ppjrhopi.cxx:53
int Ncut1
Definition: Ppjrhopi.cxx:53
int Ncut0
Definition: Ppjrhopi.cxx:53
int Ncut5
Definition: Ppjrhopi.cxx:53
int Ncut3
Definition: Ppjrhopi.cxx:53
int Ncut6
Definition: Ppjrhopi.cxx:53
int Ncut4
Definition: Ppjrhopi.cxx:53
int Ncut2
Definition: Rhopi.cxx:54
HepGeom::Point3D< double > HepPoint3D
Definition: Rhopi.cxx:34
int Ncut1
Definition: Rhopi.cxx:54
std::vector< HepLorentzVector > Vp4
Definition: Rhopi.cxx:52
int Ncut0
Definition: Rhopi.cxx:54
const double xmass[5]
Definition: Rhopi.cxx:48
int Ncut5
Definition: Rhopi.cxx:54
const double velc
Definition: Rhopi.cxx:50
int Ncut3
Definition: Rhopi.cxx:54
const double mpi
Definition: Rhopi.cxx:47
std::vector< int > Vint
Definition: Rhopi.cxx:51
int Ncut6
Definition: Rhopi.cxx:54
int Ncut4
Definition: Rhopi.cxx:54
const HepSymMatrix err() const
const HepVector helix() const
......
virtual bool isVertexValid()=0
virtual double * SigmaPrimaryVertex()=0
virtual double * PrimaryVertex()=0
void AddFourMomentum(int number, HepLorentzVector p4)
void AddResonance(int number, double mres, std::vector< int > tlis)
static KalmanKinematicFit * instance()
double chiTof2(int n) const
static ParticleID * instance()
Definition: ParticleID.cxx:22
bool IsPidInfoValid() const
double chiTof1(int n) const
void calculate()
Definition: ParticleID.cxx:97
void init()
Definition: ParticleID.cxx:27
double chiDedx(int n) const
StatusCode execute()
Definition: Rhopi.cxx:308
StatusCode finalize()
Definition: Rhopi.cxx:932
StatusCode initialize()
Definition: Rhopi.cxx:75
Rhopi(const std::string &name, ISvcLocator *pSvcLocator)
Definition: Rhopi.cxx:58
void setStatus(unsigned int status)
void AddTrack(const int number, const double mass, const RecMdcTrack *trk)
Definition: TrackPool.cxx:22
const HepPoint3D & pivot(void) const
returns pivot position.
const HepVector & a(void) const
returns helix parameters.
void init()
Definition: VertexFit.cxx:29
void AddVertex(int number, VertexParameter vpar, std::vector< int > lis)
Definition: VertexFit.cxx:89
static VertexFit * instance()
Definition: VertexFit.cxx:15
bool Fit()
Definition: VertexFit.cxx:301
const double ecms
Definition: inclkstar.cxx:42