119#ifdef MDCPATREC_TIMETEST
120 TAU_PROFILE_TIMER(timer8,
"fill ax seg",
"int ()", TAU_DEFAULT);
121 TAU_PROFILE_START(timer8);
127#ifdef MDCPATREC_TIMETEST
128 TAU_PROFILE_STOP(timer8);
131 bool goodOnly =
true;
132 bool useBad = (segs->
count() < 400);
138 seed = segs->
getSeed(0,goodOnly);
139 if (seed == 0 && goodOnly && useBad) {
144 else if (seed == 0 && (!goodOnly || !useBad)) {
148 if (3 == m_debug)
dumpSeed(seed, goodOnly);
156#ifdef MDCPATREC_TIMETEST
157 TAU_PROFILE_TIMER(timer3,
"combine ax seg",
"int ()", TAU_DEFAULT);
158 TAU_PROFILE_START(timer3);
160 int success = origSegs.
combineSegs(trialTrack, seed, context, bunchTime,
162#ifdef MDCPATREC_TIMETEST
163 TAU_PROFILE_STOP(timer3);
168 cout<<
" ***** Ax.combineSegs success? " << success<<
"\n";
171 if (!success)
continue;
175#ifdef MDCPATREC_TIMETEST
176 TAU_PROFILE_TIMER(timer4,
"circle fitting",
"int ()", TAU_DEFAULT);
177 TAU_PROFILE_START(timer4);
180#ifdef MDCPATREC_TIMETEST
181 TAU_PROFILE_STOP(timer4);
185 cout<<
"finishCircle success? " << success<<
"\n";
189 if (!success)
continue;
201 if (
tkParam.lPrint>1)cout<<__FILE__<<
" Killing track by d0:" <<par.
d0()<<
">"<<
m_d0Cut << endl;
207 if (
tkParam.lPrint>1)cout<<__FILE__<<
" Killing track by pt:" <<tkFit->
pt(0.)<<
"<"<<
m_ptCut << endl;
212 if (3 <= m_debug) std::cout <<
" *** End r-phi track-finding "<<std::endl;
215#ifdef MDCPATREC_TIMETEST
216 TAU_PROFILE_TIMER(timer5,
"fill st seg",
"int ()", TAU_DEFAULT);
217 TAU_PROFILE_START(timer5);
220#ifdef MDCPATREC_TIMETEST
221 TAU_PROFILE_STOP(timer5);
225 std::cout<<std::endl<<
"----------------------------------------"<< std::endl;
226 std::cout<<
" Segment list after St.fillWithSegs "<< std::endl;
230#ifdef MDCPATREC_TIMETEST
231 TAU_PROFILE_TIMER(timer6,
"combine st seg",
"int ()", TAU_DEFAULT);
232 TAU_PROFILE_START(timer6);
234 success = stereoSegs.
combineSegs(trialTrack, 0, context, bunchTime,
236#ifdef MDCPATREC_TIMETEST
237 TAU_PROFILE_STOP(timer6);
241 cout<<
" ***** St.combineSegs success? " << success<<
"\n";
248#ifdef MDCPATREC_TIMETEST
249 TAU_PROFILE_TIMER(timer7,
"helix fitting",
"int ()", TAU_DEFAULT);
250 TAU_PROFILE_START(timer7);
253#ifdef MDCPATREC_TIMETEST
254 TAU_PROFILE_STOP(timer7);
261 if (!success)
continue;
267 if (
tkParam.lPrint>1) {cout<<__FILE__
268 <<
" Killing track by d0 after 3d fit:" <<d0par<<
">"<<
m_d0Cut << endl;}
274 if (
tkParam.lPrint>1) {cout<<__FILE__
275 <<
" Killing track by z0:" <<z0par<<
">"<<
m_z0Cut << endl;}
285 if (3 == m_debug) std::cout <<
" ***** End one track-finding *****"<<std::endl;
309 cout <<
"Before pickHits";
310 if (is2d) cout<<
" 2d:";
318 double rEnter, rExit;
320 int wireLow, wireHigh;
321 double phiLow, phiHigh;
329 int firstInputHit = -1;
340 assert (tkStatus != 0);
342 assert (hitList != 0);
344 double d0 = par.
d0();
345 double curv = 0.5 * par.
omega();
346 double sinPhi0 =
sin(par.
phi0());
347 double cosPhi0 =
cos(par.
phi0());
351 double absd0 = fabs(d0);
354 bool willCurl =
false;
355 double rCurl = fabs(d0 + 1./curv);
363 bool reachedLastInput =
false;
364 bool hasCurled =
false;
367 bool isHotOnLayer[43];
368 if(
tkParam.pickSkipExistLayer){
369 for(
int ii=0; ii<43; ii++) isHotOnLayer[ii]=
false;
371 isHotOnLayer[ihit->layerNumber()]=
true;
378 layer = ((!lCurl) ? ( (hasCurled) ? gm->
prevLayer(layer) :
386 if (tkStatus->
is2d() && layer->view() != 0)
continue;
388 if(
tkParam.pickSkipExistLayer && isHotOnLayer[layer->layNum()])
continue;
392 bool lContinue =
true;
393 if(
tkParam.pickUitlLastLayer) {
394 if (layer == lastInputLayer) reachedLastInput =
true;
399 rEnter = layer->rOut();
405 rExit = layer->rIn();
406 if (rExit < rMin) rExit = rMin;
407 if (rEnter > rMax) rEnter = rMax;
412 rEnter = layer->rIn();
413 rExit = layer->rOut();
416 if (rExit < rMin)
continue;
435 if (rExit > rMax) rExit = rMax;
439 nCell = layer->nWires();
442 goodDriftCut = 0.5 * cellWidth * M_SQRT2 +
tkParam.pickHitMargin;
444 double deltaPhiCellWidth = 0.5 * (cellWidth * M_SQRT2)/layer->rMid();
448 int ierror = trk->
projectToR(rEnter, phiTemp, hasCurled);
449 phiEnter = phiTemp.
posRad();
451 if(6==
tkParam.lPrint) std::cout<<
" ErrMsg(warning) "
452 <<
"Error in MdcTrackList::pickHits projection, ierror " <<ierror<< std::endl;
455 ierror = trk->
projectToR(rExit, phiTemp, hasCurled);
456 phiExit = phiTemp.
posRad();
458 if(6==
tkParam.lPrint) std::cout<<
" ErrMsg(warning) "
459 <<
"Error in MdcTrackList::pickHits projection, ierror "<<ierror << std::endl;
465 std::cout<< endl<<
"--pickHit of layer "<<layer->layNum()<<
"--"<<std::endl;
466 std::cout<<
" track phiEnter "<< phiEnter.
deg()<<
" phiExit "<<phiExit.
deg()<<
" degree"<< std::endl;
468 std::cout<<
" maxInactiveResid "<<
tkParam.maxInactiveResid <<
" pickHitPhiFactor "<<
tkParam.pickHitPhiFactor<< std::endl;
469 std::cout<<
" goodDriftCut "<< goodDriftCut <<
"=sqrt(2)*0.5*"<<cellWidth<<
"+"<<
tkParam.pickHitMargin<< std::endl;
475 double t_phiHit = -999.;
476 if (curv*Bz <= 0.0) {
481 phiLow -=
tkParam.maxInactiveResid / rEnter;
482 phiHigh +=
tkParam.maxInactiveResid / rExit;
486 phiLow -=
tkParam.maxInactiveResid / rExit;
487 phiHigh +=
tkParam.maxInactiveResid / rEnter;
490 if((phiHigh>0 && phiLow<0)){
492 }
else if((phiHigh<0 && phiLow>0)){
496 double lowFloat = nCell /
Constants::twoPi * (phiLow - layer->phiOffset()) + 0.5;
497 double highFloat = nCell /
Constants::twoPi * (phiHigh - layer->phiOffset()) + 0.5;
498 wireLow = (lowFloat >= 0.0) ?
int(lowFloat) : int(floor(lowFloat));
499 wireHigh = (highFloat >= 0.0) ?
int(highFloat) : int(floor(highFloat));
502 std::cout <<
" wireLow "<<wireLow <<
" wireHigh "<<wireHigh <<
" phiLow "<<phiLow*180./
Constants::pi <<
" phiHigh "<<phiHigh*180./
Constants::pi << std::endl;
508 if(wireLow>tempN/2. && wireHigh<tempN/2.){
510 tempDiff = wireHigh+tempN - wireLow +1;
513 tempDiff = wireHigh - wireLow +1;
517 if(wireLow>wireHigh) wireLow -= nCell;
519 for (
int thisWire = wireLow; thisWire <= wireHigh; thisWire++) {
521 thisHit = map->hitWire(layer->layNum(), corrWire);
524 if(thisHit != 0) {cout<<endl<<
"test hit "; thisHit->
print(std::cout);}
525 else std::cout << endl<<
"test hit ("<<layer->layNum()<<
","<<corrWire<<
")"<< std::endl;
530 double driftDist = 0.;
533 double resid = 0., predDrift = 0.;
536 double mcTkId = -9999;
538 delx = -d0 * sinPhi0 - layer->xWire(corrWire);
539 dely = d0 * cosPhi0 - layer->yWire(corrWire);
540 predDrift = cosPhi0 * dely - sinPhi0 * delx +
541 curv * (delx * delx + dely * dely);
542 if(6==
tkParam.lPrint) cout<<
"No hit. predDrift="<<predDrift<<endl;
551 if(6==
tkParam.lPrint) { cout <<
" existing hot; " ;}
554 if (alink == 0 || pickAm) {
555 if ((!tkStatus->
is2d()) && layer->view() != 0){
558 double rw = layer->rMid();
559 double alpha = acos(1 - rw*rw/(2*rc*rc));
561 if(fabs(1 - rw*rw/(2*rc*rc))<1) fltLen = rc *
alpha;
562 z = par.
z0() + fltLen* par.
tanDip();
564 double x = layer->getWire(corrWire)->xWireDC(z);
565 double y = layer->getWire(corrWire)->yWireDC(z);
566 delx = -d0 * sinPhi0 - x;
567 dely = d0 * cosPhi0 -
y;
570 delx = -d0 * sinPhi0 - thisHit->
x();
571 dely = d0 * cosPhi0 - thisHit->
y();
574 predDrift = cosPhi0 * dely - sinPhi0 * delx +
575 curv * (delx * delx + dely * dely);
578 ambig = (predDrift >= 0) ? 1 : -1;
579 if (hasCurled) ambig = -ambig;
580 double entranceAngle=0.;
581 driftDist = thisHit->
driftDist(tof+bunchTime,ambig,entranceAngle,0.,z);
584 resid = ambig * fabs(driftDist) - predDrift;
585 aresid = fabs(resid);
589 ambig = alink->
ambig();
590 if(6==
tkParam.lPrint) cout <<
" pick ambig for hot"<<endl;
596 double zGuess = par.
z0() + layer->rMid() * par.
tanDip();
597 double phiDCz = layer->getWire(corrWire)->phiDC(zGuess);
598 BesAngle phiDCzMax(phiDCz + deltaPhiCellWidth);
599 BesAngle phiDCzMin(phiDCz - deltaPhiCellWidth);
603 if (thisHit != 0 &&alink==0) {
604 double entranceAngle = 0.;
605 sigma = thisHit->
sigma(driftDist, ambig, entranceAngle, atan(par.
tanDip()), z);
612 if((phiDCzMin-phiExit>0) || (phiDCzMax-phiEnter<0))
m_pickPhizOk[t_iHit] = 0;
615 if((phiDCzMin-phiEnter>0) || (phiDCzMax-phiExit<0))
m_pickPhizOk[t_iHit] = 0;
623 double t_phiLowCut=-999.;
624 double t_phiHighCut= -999.;
625 if(t_phiHit > -998.){
626 t_phiLowCut = (phiEnter-t_phiHit)*rEnter;
627 t_phiHighCut = (phiExit-t_phiHit)*rExit;
640 if((phiDCzMin-phiExit>0) || (phiDCzMax-phiEnter<0)) {
641 if(6==
tkParam.lPrint){ std::cout<<
" CUT by phiDCz not in phi En Ex range, curv>=0"<<std::endl; }
646 if((phiDCzMin-phiEnter>0) || (phiDCzMax-phiExit<0)) {
647 if(6==
tkParam.lPrint){ std::cout<<
" CUT by phiDCz not in phi En Ex range, curv<0"<<std::endl; }
654 if (ambig != 0 && fabs(predDrift) > goodDriftCut){
655 if(6==
tkParam.lPrint){cout<<
" predDrift "<<predDrift<<
">goodDriftCut "<<goodDriftCut<<endl;}
660 if (ambig == 0 && fabs(predDrift) > goodDriftCut){
662 cout<<
" ambig==0 && |predDirft| "<<fabs(predDrift) <<
"> goodDriftCut "<< goodDriftCut<<endl;
663 cout<<
" No good hit, but track near cell-edge " << endl;
673 double entranceAngle = 0.;
674 double sigma = thisHit->
sigma(driftDist, ambig, entranceAngle, atan(par.
tanDip()), z);
675 double factor =
tkParam.pickHitFactor;
678 double residCut =
tkParam.maxActiveSigma * factor *
sigma;
683 if (alink == 0 && (aresid <= residCut) ) {
685 cout <<
" (2) New hit found " << endl;
699 if(6==
tkParam.lPrint) std::cout<<
" thisHit used, setUsability false " << std::endl;
702 double flt = layer->rMid();
704 flt += 0.000001 * (thisHit->
x() + thisHit->
y());
707 std::cout<<
" aresid "<<aresid<<
"<=residCut " <<residCut<<
" nSig "<<aresid/
sigma<<
" nSigCut "<<(
tkParam.maxActiveSigma*factor)<<
" factor "<<factor<<
" maxActiveSigma "<<
tkParam.maxActiveSigma<<
" tanDip "<<par.
tanDip()<<std::endl;
708 std::cout<<
" Append Hot " << std::endl;
714 std::cout<<
"Exist hot found"<<std::endl;
715 }
else if(aresid > residCut){
716 thisHit->
print(std::cout);
717 std::cout<<
" Drop hit. aresid "<<aresid<<
">residCut " <<residCut<<
" nSig "<<aresid/
sigma<<
" nSigCut "<<(
tkParam.maxActiveSigma*factor)<<
" factor "<<factor<<
" maxActiveSigma "<<
tkParam.maxActiveSigma<<
" tanDip "<<par.
tanDip()<<std::endl;
721 if (!localHistory.member(
const_cast<MdcHitOnTrack*
>(alink))) {
725 if(6==
tkParam.lPrint) std::cout<<
" nFound="<<nFound<<
" nCand "<<nCand<<std::endl;
726 if (layer == firstInputLayer && firstInputHit < 0) {
727 firstInputHit = nCand;
730 if(6==
tkParam.lPrint) std::cout <<
"ErrMsg(warning) "<<
"would have inserted identical HOT "
731 "twice in history buffer" << std::endl;
736 else if (ambig == 0 && reachedLastInput) {
737 if(6==
tkParam.lPrint) std::cout <<
"ambig==0 "<<std::endl;
741 if (nCand < 8) last = nCand;
742 for (
int i = 0; i < last; i++) {
743 int j = nCand - 1 - i;
744 if (localHistory[j] != 0) {
748 if (i == 2 && nSuccess >= 2) lContinue =
true;
749 if (i == 4 && nSuccess >= 3) lContinue =
true;
750 if (i == 7 && nSuccess >= 5) lContinue =
true;
751 if(6==
tkParam.lPrint) cout <<i<<
" (3) No hit found; if beyond known good region " << endl;
753 if(6==
tkParam.lPrint) std::cout<<
" pickHits break by lContinue. i="<<i<<
" nSuccess="<<nSuccess<< std::endl;
758 if(6==
tkParam.lPrint) cout <<
" (3) No hit found; if beyond known good region " << endl;
764 localHistory.append(0);
769 if (ambig != 0 && reachedLastInput) {
790 if (!lContinue && reachedLastInput) {
797 bool lContinue =
true;
798 for (
int ihit = firstInputHit; ihit >= 0; ihit--) {
799 if (localHistory[ihit] != 0) {
802 const MdcHitOnTrack *mdcHit = localHistory[ihit]->mdcHitOnTrack();
812 std::cout <<
" gap found; delete hits. ";
814 if (!localHistory[ihit]->isUsable()) {
816 cout <<
"about to delete hit for unusable HOT:" << endl;
817 localHistory[ihit]->print(std::cout);
819 hitList->
removeHit(localHistory[ihit]->hit());
822 cout <<
" current contents of localHistory: "
823 <<localHistory.length()<<
"hot" << endl;
831 else if (localHistory[ihit] == 0) {
832 if(6==
tkParam.lPrint){ cout <<
" localHistory= 0 " << endl; }
836 if (nCand < 8) last = nCand;
837 for (
int i = 0; i < last; i++) {
838 int j = ihit + 1 + i;
839 if (localHistory[j] != 0) nSuccess++;
840 if (i == 2 && nSuccess >= 2) lContinue =
true;
841 if (i == 4 && nSuccess >= 3) lContinue =
true;
843 if (lContinue)
break;
848 std::cout<<
"nFound="<<nFound <<
" < "<<
tkParam.pickHitFract*nCand<<
" pickHitFract? "<<
tkParam.pickHitFract<<
"*"<<nCand << std::endl;
850 if (nFound <
tkParam.pickHitFract * nCand) nFound = 0;
851 if(6==
tkParam.lPrint){ cout <<
" localHistory= 0 " << endl; }
854 cout <<
"After pickHits found " << nFound <<
" hit(s)"<< endl;
856 std::cout<< std::endl;