ATLAS Offline Software
TRT_TrackSegmentsMaker_ECcosmics.cxx
Go to the documentation of this file.
1 /*
2  Copyright (C) 2002-2025 CERN for the benefit of the ATLAS collaboration
3 */
4 
6 // Implementation file for class TRT_TrackSegmentsMaker_ECcosmics
8 // (c) ATLAS Detector software
10 
11 
12 
13 #include "TrkSurfaces/Surface.h"
21 #include "TGraphErrors.h"
22 #include "TF1.h"
23 #include "TVirtualFitter.h"
25 
26 #include "StoreGate/ReadHandle.h"
27 #include <cmath>
28 
29 
30 
32 // Constructor
34 
36 (const std::string& t,const std::string& n,const IInterface* p)
37  : AthAlgTool(t,n,p)
38 {
39  declareInterface<ITRT_TrackSegmentsMaker>(this);
40 }
41 
43 // Destructor
45 
47 = default;
48 
49 
51 // Fitting functions
53 
54 Double_t fitf_ztanphi(const Double_t *x, const Double_t *par)
55 {
56  Double_t f = par[0]*(x[0]+par[1])/(x[0]+par[2]);
57  return f;
58 }
59 
60 Double_t fitf_zphi(const Double_t *x, const Double_t *par)
61 {
62  Double_t f = std::atan(par[0]*(x[0]+par[1])/(x[0]+par[2]));
63  return f;
64 }
65 
66 Double_t fitf_zphi_approx(const Double_t *x, const Double_t *par)
67 {
68  Double_t f = par[0]+par[1]*x[0]+par[2]*x[0]*x[0];
69  return f;
70 }
71 
73 // Initialisation
75 
77 {
79 
80  // Initialize ReadHandle
82 
83  // TRT
84  if (detStore()->retrieve(m_trtid, "TRT_ID").isFailure()) {
85  ATH_MSG_FATAL("Could not get TRT ID helper");
86  return StatusCode::FAILURE;
87  }
88 
89  // Get RIO_OnTrack creator with drift time information
90  //
91  if( m_riomakerD.retrieve().isFailure()) {
92  ATH_MSG_FATAL("Failed to retrieve tool "<< m_riomakerD);
93  return StatusCode::FAILURE;
94  }
95  ATH_MSG_DEBUG("Retrieved tool " << m_riomakerD);
96 
97  // Get RIO_OnTrack creator without drift time information
98  //
99 
100  if( m_riomakerN.retrieve().isFailure()) {
101  ATH_MSG_FATAL("Failed to retrieve tool "<< m_riomakerN);
102  return StatusCode::FAILURE;
103  }
104  ATH_MSG_DEBUG("Retrieved tool " << m_riomakerN);
105 
106  // optional PRD to track association map
107  //
109 
110 
111  return sc;
112 }
113 
114 
116  std::string fit_name1="ztanphi";
117  std::string fit_name2="zphi";
118  std::string fit_name3="zphi_ap";
119 
120  if(m_phaseMode){
121  fit_name1+="_phase";
122  fit_name2+="_phase";
123  fit_name3+="_phase";
124  }
125 
126  if(!m_prdToTrackMap.key().empty()){
127  fit_name1+="_asso";
128  fit_name2+="_asso";
129  fit_name3+="_asso";
130  }
131 
132  fit_name1+=name();
133  fit_name2+=name();
134  fit_name3+=name();
135 
136  event_data.m_fitf_ztanphi = new TF1(fit_name1.c_str(),fitf_ztanphi,-3000,3000,3);
137  event_data.m_fitf_zphi = new TF1(fit_name2.c_str(),fitf_zphi,-3000,3000,3);
138  event_data.m_fitf_zphi_approx = new TF1(fit_name3.c_str(),fitf_zphi_approx,-3000,3000,3);
139 }
140 
142 // Finalize
144 
146 {
148  return sc;
149 }
150 
152 // Initialize tool for new event
154 
155 std::unique_ptr<InDet::ITRT_TrackSegmentsMaker::IEventData>
156 InDet::TRT_TrackSegmentsMaker_ECcosmics::newEvent (const EventContext& /*ctx*/) const
157 {
158 
159  std::unique_ptr<TRT_TrackSegmentsMaker_ECcosmics::EventData>
160  event_data = std::make_unique<TRT_TrackSegmentsMaker_ECcosmics::EventData>();
161 
162  setFitFunctions(*event_data);
163  //sort into good/noise hits
164  retrieveHits(*event_data);
165 
167  it=event_data->m_goodHits.begin();
168  itE=event_data->m_goodHits.end();
169 
170  //loop over good hits and sort them into sectors
171 
172  for(;it!=itE;++it){
173 
174  int straw = m_trtid->straw((*it)->identify());
175  const Amg::Vector3D& sc = (*it)->detectorElement()->strawCenter(straw);
176 
177  int phi = int((std::atan2(sc.y(),sc.x())+M_PI)*8./M_PI);
178 
179  if ( phi<0 ) phi = 15;
180  else if( phi>15 ) phi = 0 ;
181 
182  int z=0;
183  if(sc.z()<0) z=1;
184 
185  int zslice=int((std::abs(sc.z())-800.)/100.);
186 
187  event_data->m_sectors[z][zslice][phi].push_back(*it);
188 
189  }
190 
191  ATH_MSG_DEBUG("Number of good driftcircles: "<<event_data->m_goodHits.size());
192  ATH_MSG_DEBUG("Number of noise driftcircles: "<<event_data->m_noiseHits.size());
193 
194  return std::unique_ptr<InDet::ITRT_TrackSegmentsMaker::IEventData>(event_data.release());
195 }
196 
198 // Initialize tool for new region
200 
201 std::unique_ptr<InDet::ITRT_TrackSegmentsMaker::IEventData>
203 (const EventContext& /*ctx*/, const std::vector<IdentifierHash>& vTRT) const
204 {
205  (void) vTRT;
206  std::unique_ptr<TRT_TrackSegmentsMaker_ECcosmics::EventData>
207  event_data = std::make_unique<TRT_TrackSegmentsMaker_ECcosmics::EventData>();
208 
209  setFitFunctions(*event_data);
210 
211  // @TODO here the retrieve_hits method should be called with the list of the idhash
212 
213 
215  it=event_data->m_goodHits.begin();
216  itE=event_data->m_goodHits.end();
217 
218  //loop over good hits and sort them into sectors
219 
220  for(;it!=itE;++it){
221 
222  int straw = m_trtid->straw((*it)->identify());
223  const Amg::Vector3D& sc = (*it)->detectorElement()->strawCenter(straw);
224 
225  int phi = int((std::atan2(sc.y(),sc.x())+M_PI)*8./M_PI);
226 
227  if ( phi<0 ) phi = 15;
228  else if( phi>15 ) phi = 0 ;
229 
230  int z=0;
231  if(sc.z()<0) z=1;
232  int zslice=int((std::abs(sc.z())-800.)/100.);
233 
234  event_data->m_sectors[z][zslice][phi].push_back(*it);
235 
236  }
237 
238  ATH_MSG_DEBUG("Number of good driftcircles: "<<event_data->m_goodHits.size());
239  ATH_MSG_DEBUG("Number of noise driftcircles: "<<event_data->m_noiseHits.size());
240 
241  return std::unique_ptr<InDet::ITRT_TrackSegmentsMaker::IEventData>(event_data.release());
242 }
243 
245 // Inform tool about end of event or region investigation
247 
249 {
250 }
251 
252 
253 
255 // Helper function to sort the DC along z
257 
258 namespace InDet{
260  {
261  const Amg::Vector3D& sc = x->detectorElement()->center();
262  double z1=sc.z();
263 
264 
265  const Amg::Vector3D& sc2 = y->detectorElement()->center();
266  double z2=sc2.z();
267 
268  return z1<z2;
269  }
270 
272  {
273  const Amg::Vector3D& sc = x->detectorElement()->center();
274  double y1=sc.y();
275 
276 
277  const Amg::Vector3D& sc2 = y->detectorElement()->center();
278  double y2=sc2.y();
279 
280  return y1>y2;
281  }
282 
284  {
285  const Amg::Vector3D& sc = x->detectorElement()->center();
286  double z1=sc.z();
287 
288 
289  const Amg::Vector3D& sc2 = y->detectorElement()->center();
290  double z2=sc2.z();
291 
292  return z1>z2;
293  }
294 }
295 
296 
297 
299 // Methods of TRT segment reconstruction in one event
301 
302 void InDet::TRT_TrackSegmentsMaker_ECcosmics::find(const EventContext & /*ctx*/,
305 {
308 
309 
310 
311  //loop over both endcaps
312  for(int endcap=0;endcap<2;endcap++){
313 
314  // 1st step: find sector with the maximal number of hits until no one is left
315  // with at least 5 hits
316 
317  int max=m_minDCSeed;
318 
319  while(max>=m_minDCSeed){
320  max=-1;
321  int sector=-1;
322  int zslice=-1;
323 
324  for(int j=0;j<20;j++){
325  for(int i=0;i<16;i++){
326  int count=event_data.m_sectors[endcap][j][i].size();
327 
328  if(count>0)
329  ATH_MSG_VERBOSE("Endcap "<<endcap<<" zslice "<<j<<" sector "<<i<<" : "<<count);
330 
331  if(count>max){
332  max=count;
333  sector=i;
334  zslice=j;
335  }
336  }
337  }
338 
339  if(sector<0) continue; // no hits in this endcap ...
340 
341  max=event_data.m_sectors[endcap][zslice][sector].size();
342 
343  //check if enough driftcircles present
344  if(max>=3){
345  ATH_MSG_VERBOSE("Number of DCs in seed sector: "<<max);
346 
347  //2nd step: find seed among those driftcircles
348 
349  bool found=find_seed(endcap,zslice,sector,event_data);
350 
351  //if no seed is found we clear the sector
352  if(!found){
353  event_data.m_sectors[endcap][zslice][sector].clear();
354  }
355  }
356 
357  }
358  }
359 
360  ATH_MSG_DEBUG("Found "<<event_data.m_seeds.size()<<" initial seeds !");
361 
362 
363  //now loop over all seeds and try to create segments out of them
364 
365  std::vector<std::vector<const InDet::TRT_DriftCircle*> *>::iterator sit,sitE;
366 
367  sit=event_data.m_seeds.begin();
368  sitE=event_data.m_seeds.end();
369 
370  for(;sit!=sitE;++sit){
371  create_segment(*sit, event_data);
372  }
373 
374 
375  ATH_MSG_DEBUG("Found "<<event_data.m_segments.size()<<" TRT Segments");
376 
377  event_data.m_segiterator = event_data.m_segments.begin();
378 }
379 
380 
382 // Find seeds
384 
385 
387  int zslice,
388  int sector,
390 {
391  double shift=0.;
392  double phimin=10.;
393  double phimax=-10.;
394 
395  std::vector<const InDet::TRT_DriftCircle*> dc;
397 
398  dc.reserve(event_data.m_sectors[endcap][zslice][sector].size());
399  itE=event_data.m_sectors[endcap][zslice][sector].end();
400  for(it=event_data.m_sectors[endcap][zslice][sector].begin();it!=itE;++it){
401  dc.push_back(*it);
402  }
403  //sort them along z
404 
405  std::sort(dc.begin(),dc.end(), CompareDCz);
406 
408  vit=dc.begin();
409  vitE=dc.end();
410 
411  ATH_MSG_VERBOSE("Sorted driftcircles: "<<dc.size());
412 
413  for(;vit!=vitE;++vit){
414  int straw = m_trtid->straw((*vit)->identify());
415  const Amg::Vector3D& sc = (*vit)->detectorElement()->strawCenter(straw);
416 
417  ATH_MSG_VERBOSE("z="<<sc.z()<<" phi="<<sc.phi());
418 
419  }
420 
421 
422  //sanity check: if more than 40 good hits per seed -> not a pure cosmic event!
423 
424  if(dc.size()>=40) return false;
425 
426  //fill arrays for the fit
427 
428  vit=dc.begin();
429  vitE=dc.end();
430 
431 
432  for(;vit!=vitE;++vit){
433  int straw = m_trtid->straw((*vit)->identify());
434  const Amg::Vector3D& sc = (*vit)->detectorElement()->strawCenter(straw);
435 
436  if(sc.phi()<phimin)
437  phimin=sc.phi();
438 
439  if(sc.phi()>phimax)
440  phimax=sc.phi();
441  }
442 
443  shift=(phimax+phimin)/2.-M_PI_4;
444  ATH_MSG_VERBOSE("Phimin="<<phimin<<" Phimax="<<phimax<<" -> shift = "<<shift);
445 
446  //protection for boundary at pi,-pi
447  if(phimin<-M_PI_2 && phimax>M_PI_2){
448  shift=3.*M_PI_4;
449  ATH_MSG_VERBOSE("Boundary between pi and -pi!!! use the following shift: "<<shift);
450  }
451 
452 
453  int count=0;
454  for(vit=dc.begin();vit!=vitE;++vit){
455  int straw = m_trtid->straw((*vit)->identify());
456  const Amg::Vector3D& sc = (*vit)->detectorElement()->strawCenter(straw);
457 
458  double orig=sc.phi();
459 
460  double corr=orig-shift;
461 
462  if (corr > M_PI) corr = std::fmod(corr+M_PI,2.*M_PI)-M_PI;
463  else if(corr <-M_PI) corr = std::fmod(corr-M_PI,2.*M_PI)+M_PI;
464 
465  if(count>500){
466  return false; // a seed cannot contain that many hits
467  }
468 
469  event_data.m_a_z[count]=sc.z();
470  event_data.m_a_phi[count]=corr;
471  count++;
472  }
473 
474  int maxdc=0;
475  double p_best[3]={0,0,0};
476  p_best[2]=shift;
477 
478  for(int i=0;i<count;i++){
479  for(int j=i+1;j<count;j++){
480 
481  double p[3];
482 
483  p[2]=shift;
484 
485  if(event_data.m_a_z[i]==event_data.m_a_z[j]){
486  p[0]=1e10;
487  p[1]=event_data.m_a_z[i];
488  }else{
489  p[0]=(event_data.m_a_phi[i]-event_data.m_a_phi[j])/(event_data.m_a_z[i]-event_data.m_a_z[j]);
490  p[1]=event_data.m_a_phi[j]-p[0]*event_data.m_a_z[j];
491  }
492 
493 
494 
495  int match=evaluate_seed(endcap,zslice,sector,p,event_data);
496 
497  if(match>maxdc){
498  maxdc=match;
499  p_best[0]=p[0];
500  p_best[1]=p[1];
501  }
502  }
503  }
504 
505  ATH_MSG_VERBOSE("Number of matching dc from best seed: "<<maxdc);
506 
507 
508  if(maxdc>=4){
509  //ok, we've found a seed
510 
511  double zmin=1e4;
512  double zmax=-1e4;
513 
514 
515  int muster[3][3];
516  for(auto & i : muster)
517  for(int & j : i)
518  j=0;
519 
520  std::vector<const InDet::TRT_DriftCircle*> *seed=new std::vector<const InDet::TRT_DriftCircle*>;
521 
522  for(int zsl=zslice-1;zsl<=zslice+1;zsl++){
523  for(int ps=sector-1;ps<=sector+1;ps++){
524 
525  //make sure that the slices exist ...
526  if(zsl<0 || zsl>=20) continue;
527 
528  int ps2=ps;
529  if(ps2<0) ps2+=16;
530  else if(ps2>15) ps2-=16;
531 
532  for(it=event_data.m_sectors[endcap][zsl][ps2].begin();it!=event_data.m_sectors[endcap][zsl][ps2].end();++it){
533  int straw = m_trtid->straw((*it)->identify());
534  const Amg::Vector3D& sc = (*it)->detectorElement()->strawCenter(straw);
535 
536  double pred_phi=sc.z()*p_best[0]+p_best[1];
537  double corr=sc.phi()-p_best[2];
538 
539  if(p_best[0]==1e10){
540  if(sc.z()==p_best[1]) {
541  pred_phi=corr; //z=const ...
542  }else{
543  pred_phi=corr+0.5;
544  }
545  }
546  if (corr > M_PI) corr = std::fmod(corr+M_PI,2.*M_PI)-M_PI;
547  else if(corr <-M_PI) corr = std::fmod(corr-M_PI,2.*M_PI)+M_PI;
548 
549 
550  if(std::abs(phidiff(pred_phi,corr))<=4./650.){
551  seed->push_back(*it);
552  if(sc.z()<zmin) zmin=sc.z();
553  if(sc.z()>zmax) zmax=sc.z();
554  muster[zsl-zslice+1][ps-sector+1]=1;
555  }
556  }
557  }
558  }
559 
561 
562 
563  //do we need to extend the range ??
564 
565  ATH_MSG_VERBOSE("Pattern:");
566  ATH_MSG_VERBOSE("\t"<<muster[0][0]<<" "<<muster[1][0]<<" "<<muster[2][0]);
567  ATH_MSG_VERBOSE("\t"<<muster[0][1]<<" "<<muster[1][1]<<" "<<muster[2][1]);
568  ATH_MSG_VERBOSE("\t"<<muster[0][2]<<" "<<muster[1][2]<<" "<<muster[2][2]);
569 
570  int zsl=-1;
571  if(muster[2][0] || muster[2][1] || muster[2][2]){
572  //extend towards higher z-values
573  zsl=zslice+2;
574 
575  for(int ps=sector-2;ps<=sector+2;ps++){
576 
577  //make sure that the slices exist ...
578  if(zsl<0 || zsl>=20) continue;
579 
580  int ps2=ps;
581  if(ps2<0) ps2+=16;
582  else if(ps2>15) ps2-=16;
583 
584  for(it=event_data.m_sectors[endcap][zsl][ps2].begin();it!=event_data.m_sectors[endcap][zsl][ps2].end();++it){
585  int straw = m_trtid->straw((*it)->identify());
586  const Amg::Vector3D& sc = (*it)->detectorElement()->strawCenter(straw);
587 
588  double pred_phi=sc.z()*p_best[0]+p_best[1];
589  double corr=sc.phi()-p_best[2];
590 
591  if(p_best[0]==1e10){
592  if(sc.z()==p_best[1]) {
593  pred_phi=corr; //z=const ...
594  }else{
595  pred_phi=corr+0.5;
596  }
597  }
598  if (corr > M_PI) corr = std::fmod(corr+M_PI,2.*M_PI)-M_PI;
599  else if(corr <-M_PI) corr = std::fmod(corr-M_PI,2.*M_PI)+M_PI;
600 
601 
602  if(std::abs(phidiff(pred_phi,corr))<=4./650.){
603  if (msgLvl(MSG::VERBOSE)) msg()<<"extended hit at z= "<<sc.z()<<endmsg;
604  if(sc.z()<zmin) zmin=sc.z();
605  if(sc.z()>zmax) zmax=sc.z();
606  seed->push_back(*it);
607  }
608  }
609  }
610  }
611 
612  if(muster[0][0] || muster[0][1] || muster[0][2]){
613  //extend towards lower z-values
614  zsl=zslice-2;
615 
616  for(int ps=sector-2;ps<=sector+2;ps++){
617 
618  //make sure that the slices exist ...
619  if(zsl<0 || zsl>=20) continue;
620 
621  int ps2=ps;
622  if(ps2<0) ps2+=16;
623  else if(ps2>15) ps2-=16;
624 
625  for(it=event_data.m_sectors[endcap][zsl][ps2].begin();it!=event_data.m_sectors[endcap][zsl][ps2].end();++it){
626  int straw = m_trtid->straw((*it)->identify());
627  const Amg::Vector3D& sc = (*it)->detectorElement()->strawCenter(straw);
628 
629  double pred_phi=sc.z()*p_best[0]+p_best[1];
630  double corr=sc.phi()-p_best[2];
631 
632  if(p_best[0]==1e10){
633  if(sc.z()==p_best[1]) {
634  pred_phi=corr; //z=const ...
635  }else{
636  pred_phi=corr+0.5;
637  }
638  }
639  if (corr > M_PI) corr = std::fmod(corr+M_PI,2.*M_PI)-M_PI;
640  else if(corr <-M_PI) corr = std::fmod(corr-M_PI,2.*M_PI)+M_PI;
641 
642 
643  if(std::abs(phidiff(pred_phi,corr))<=4./650.){
644  ATH_MSG_VERBOSE("extended hit at z= "<<sc.z());
645  if(sc.z()<zmin) zmin=sc.z();
646  if(sc.z()>zmax) zmax=sc.z();
647  seed->push_back(*it);
648  }
649  }
650  }
651  }
652 
653 
654  if(seed->size()<(size_t)m_minDCSeed){
655  ATH_MSG_VERBOSE("Seed has too few hits: "<<seed->size());
656  seed->clear();
657  delete seed;
658  return false;
659  }
660 
661 
662  vit=seed->begin();
663  vitE=seed->end();
664 
665  for(;vit!=vitE;++vit){
666  int straw = m_trtid->straw((*vit)->identify());
667  const Amg::Vector3D& sc = (*vit)->detectorElement()->strawCenter(straw);
668 
669  int phi = int((std::atan2(sc.y(),sc.x())+M_PI)*8./M_PI);
670 
671  if ( phi<0 ) phi = 15;
672  else if( phi>15 ) phi = 0 ;
673 
674  int z=0;
675  if(sc.z()<0) z=1;
676  int zslic=int((std::abs(sc.z())-800.)/100.);
677 
678  event_data.m_sectors[z][zslic][phi].remove(*vit);
679 
680  }
681 
682  //just to be sure: check also the noise hits in these 9 slices
683 
685  lit=event_data.m_noiseHits.begin();
686  litE=event_data.m_noiseHits.end();
687 
688  for(;lit!=litE;++lit){
689 
690  //don't add hits that really look like noise
691  if((*lit)->timeOverThreshold()<m_cutToTLoose) continue;
692 
693  int straw = m_trtid->straw((*lit)->identify());
694  const Amg::Vector3D& sc = (*lit)->detectorElement()->strawCenter(straw);
695 
696  int phi = int((std::atan2(sc.y(),sc.x())+M_PI)*8./M_PI);
697 
698  if ( phi<0 ) phi = 15;
699  else if( phi>15 ) phi = 0 ;
700 
701 
702  int zsl=int((std::abs(sc.z())-800.)/100.);
703 
704  if(std::abs(zsl-zslice)<2){
705  double pred_phi=sc.z()*p_best[0]+p_best[1];
706  double corr=sc.phi()-p_best[2];
707 
708  if(p_best[0]==1e10){
709  if(sc.z()==p_best[1]) {
710  pred_phi=corr; //z=const ...
711  }else{
712  pred_phi=corr+0.5;
713  }
714  }
715  if (corr > M_PI) corr = std::fmod(corr+M_PI,2.*M_PI)-M_PI;
716  else if(corr <-M_PI) corr = std::fmod(corr-M_PI,2.*M_PI)+M_PI;
717 
718 
719  if(std::abs(phidiff(pred_phi,corr))<=4./650.){
720  if(sc.z()>zmin && sc.z()<zmax){
721  seed->push_back(*lit);
722  ATH_MSG_VERBOSE("\t\t noise hit matched seed! z="<< sc.z());
723  }
724  }
725 
726  }
727 
728 
729  }
730 
731 
732 
733 
734  event_data.m_seeds.push_back(seed);
735 
736  return true;
737  }
738 
739 
740  return false;
741 
742 }
743 
745  int zslice,
746  int sector,
747  const double *p,
749 {
750 
752 
753  int count=0;
754 
755  //look at all nearest neighbours ...
756 
757  for(int zsl=zslice-1;zsl<=zslice+1;zsl++){
758  for(int ps=sector-1;ps<=sector+1;ps++){
759 
760  //make sure that the slices exist ...
761  if(zsl<0 || zsl>=20) continue;
762 
763  int ps2=ps;
764  if(ps2<0) ps2+=16;
765  else if(ps2>15) ps2-=16;
766 
767 
768  itE=event_data.m_sectors[endcap][zsl][ps2].end();
769  for(it=event_data.m_sectors[endcap][zsl][ps2].begin();it!=itE;++it){
770  int straw = m_trtid->straw((*it)->identify());
771  const Amg::Vector3D& sc = (*it)->detectorElement()->strawCenter(straw);
772 
773  double pred_phi=sc.z()*p[0]+p[1];
774  double corr=sc.phi()-p[2];
775 
776  if(p[0]==1e10){
777  if(sc.z()==p[1]) {
778  pred_phi=corr; //z=const ...
779  }else{
780  pred_phi=corr+0.5;
781  }
782  }
783  if (corr > M_PI) corr = std::fmod(corr+M_PI,2.*M_PI)-M_PI;
784  else if(corr <-M_PI) corr = std::fmod(corr-M_PI,2.*M_PI)+M_PI;
785 
786 
787  if(std::abs(phidiff(pred_phi,corr))<=4./650.){
788  count=count+1;
789  }
790  }
791  }
792  }
793 
794 
795  return count;
796 }
797 
798 
799 void InDet::TRT_TrackSegmentsMaker_ECcosmics::create_segment(std::vector<const InDet::TRT_DriftCircle*> *seed,
801 {
802 
803  ATH_MSG_VERBOSE("Number of hits in initial seed: "<<seed->size());
804 
805  double shift=0.;
806  double phimin=10.;
807  double phimax=-10.;
808 
809  double zmin=1e5;
810  double zmax=-1e5;
811 
813 
814  vit=seed->begin();
815  vitE=seed->end();
816 
817  int count=0;
818  for(;vit!=vitE;++vit){
819  int straw = m_trtid->straw((*vit)->identify());
820  const Amg::Vector3D& sc = (*vit)->detectorElement()->strawCenter(straw);
821 
822  if(sc.z()<zmin) zmin=sc.z();
823  if(sc.z()>zmax) zmax=sc.z();
824 
825  if(count>500){
826  return; // a seed cannot contain that many hits
827  }
828 
829  event_data.m_a_z[count]=sc.z();
830  event_data.m_a_phi[count]=sc.phi();
831  event_data.m_a_tan[count]=std::tan(sc.phi());
832  const auto cosPhi{std::cos(sc.phi())};
833  event_data.m_a_tan_err[count]=(1.15/700.)/(cosPhi*cosPhi);
834  event_data.m_a_z_err[count]=1.15; // 4/sqrt(12)
835  event_data.m_a_phi_err[count]=1.15/700.; //take uncertainty at a radius of 700 mm
836 
837  if(sc.phi()<phimin)
838  phimin=sc.phi();
839 
840  if(sc.phi()>phimax)
841  phimax=sc.phi();
842 
843  count++;
844  }
845 
846  shift=(phimax+phimin)/2.-M_PI_4;
847  ATH_MSG_VERBOSE("Phimin="<<phimin<<" Phimax="<<phimax<<" shift="<<shift);
848 
849  //protection for boundary at pi,-pi
850  if(phimin<-M_PI_2 && phimax>M_PI_2){
851  shift=3.*M_PI_4;
852  ATH_MSG_VERBOSE("Boundary between pi and -pi!!! use the following shift: "<<shift);
853  }
854 
855 
856  //correct the phi values
857 
858  for(int i=0;i<count;i++){
859  double orig=event_data.m_a_phi[i];
860 
861  double corr=orig-shift;
862  if (corr > M_PI) corr = std::fmod(corr+M_PI,2.*M_PI)-M_PI;
863  else if(corr <-M_PI) corr = std::fmod(corr-M_PI,2.*M_PI)+M_PI;
864 
865  event_data.m_a_phi[i]=corr;
866  event_data.m_a_tan[i]=std::tan(corr);
867  const auto cosCorr{std::cos(corr)};
868  event_data.m_a_tan_err[i]=(1.15/700.)/(cosCorr*cosCorr);
869  }
870 
871  TF1 *fit=perform_fit(count, event_data);
872  if(!fit) return;
873 
875 
876  //add the ones from the good list (but skip the ones that we already have)
877  lit=event_data.m_goodHits.begin();
878  litE=event_data.m_goodHits.end();
879 
880  std::vector<const InDet::TRT_DriftCircle*> tobeadded;
881 
882 
883  for(;lit!=litE;++lit){
884  int straw = m_trtid->straw((*lit)->identify());
885  const Amg::Vector3D& sc = (*lit)->detectorElement()->strawCenter(straw);
886 
887  double fitted_phi=fit->Eval(sc.z(),0.,0.);
888  fitted_phi+=shift;
889 
890  if (fitted_phi > M_PI) fitted_phi = std::fmod(fitted_phi+M_PI,2.*M_PI)-M_PI;
891  else if(fitted_phi <-M_PI) fitted_phi = std::fmod(fitted_phi-M_PI,2.*M_PI)+M_PI;
892 
893  if(std::abs(phidiff(fitted_phi,sc.phi()))<m_scaleTube*4./800.){
894  //verify that this hit is not already included
895 
896  vit=seed->begin();
897  vitE=seed->end();
898  bool new_hit=true;
899  for(;vit!=vitE && new_hit;++vit){
900  if((*vit)==(*lit)){
901  new_hit=false;
902  }
903  }
904  if(new_hit){
905  ATH_MSG_VERBOSE("\t\t good hit matched! fitted_phi="<<fitted_phi<<" z=" <<sc.z());
906 
907  if(sc.z()>zmin-200 && sc.z()<zmax+200){
908  if(sc.z()<zmin) zmin=sc.z();
909  if(sc.z()>zmax) zmax=sc.z();
910 
911  seed->push_back(*lit);
912  }else{
913  //not sure if this is really a good hit yet ...
914  tobeadded.push_back(*lit);
915  }
916  }
917  }
918  }
919 
920  std::sort(tobeadded.begin(),tobeadded.end(), CompareDCz);
921 
922  int index1=-1,index2=-1;
923 
924  double z1=-1e5;
925 
926  count=0;
927  ATH_MSG_VERBOSE("zmin="<<zmin<<" zmax="<<zmax);
928  for(vit=tobeadded.begin();vit!=tobeadded.end();++vit){
929  int straw = m_trtid->straw((*vit)->identify());
930  const Amg::Vector3D& sc = (*vit)->detectorElement()->strawCenter(straw);
931  ATH_MSG_VERBOSE("Shall we add hit at z="<<sc.z());
932 
933  if(sc.z()<zmin && sc.z()>z1) {
934  z1=sc.z();
935  index1=count;
936  }
937  if(sc.z()>zmax && index2==-1) {
938  index2=count;
939  }
940  count++;
941  }
942 
943  ATH_MSG_VERBOSE("index1="<<index1<<" index2="<<index2);
944 
945  if(index2>=0){
946  for(int i=index2;i<count;i++){
947  int straw = m_trtid->straw(tobeadded[i]->identify());
948  const Amg::Vector3D& sc = tobeadded[i]->detectorElement()->strawCenter(straw);
949  if(sc.z()<zmax+200){
950  zmax=sc.z();
951  seed->push_back(tobeadded[i]);
952  ATH_MSG_VERBOSE(" added goot hit at z="<<sc.z());
953  }else{
954  ATH_MSG_VERBOSE(" rejected goot hit at z="<<sc.z());
955  i=count;
956  }
957  }
958  }
959  if(index1>=0){
960  for(int i=index1;i>=0;i--){
961  int straw = m_trtid->straw(tobeadded[i]->identify());
962  const Amg::Vector3D& sc = tobeadded[i]->detectorElement()->strawCenter(straw);
963  if(sc.z()>zmin-200){
964  zmin=sc.z();
965  seed->push_back(tobeadded[i]);
966  ATH_MSG_VERBOSE(" added goot hit at z="<<sc.z());
967  }else{
968  ATH_MSG_VERBOSE(" rejected goot hit at z="<<sc.z());
969  i=-1;
970  }
971  }
972  }
973  tobeadded.clear();
974 
975 
976 
977  //fit again
978  std::sort(seed->begin(),seed->end(), CompareDCz);
979 
980  vit=seed->begin();
981  vitE=seed->end();
982 
983  count=0;
984  for(;vit!=vitE;++vit){
985  int straw = m_trtid->straw((*vit)->identify());
986  const Amg::Vector3D& sc = (*vit)->detectorElement()->strawCenter(straw);
987 
988  if(count>500){
989  return; // a seed cannot contain that many hits
990  }
991 
992  event_data.m_a_z[count]=sc.z();
993  event_data.m_a_phi[count]=sc.phi();
994  event_data.m_a_tan[count]=std::tan(sc.phi());
995  const auto cosPhi{std::cos(sc.phi())};
996  event_data.m_a_tan_err[count]=(1.15/700.)/(cosPhi*cosPhi);
997  event_data.m_a_z_err[count]=1.15; // 4/sqrt(12)
998  event_data.m_a_phi_err[count]=1.15/700.; //take uncertainty at a radius of 700 mm
999 
1000  if(sc.phi()<phimin)
1001  phimin=sc.phi();
1002 
1003  if(sc.phi()>phimax)
1004  phimax=sc.phi();
1005 
1006  count++;
1007  }
1008 
1009  shift=(phimax+phimin)/2.-M_PI_4;
1010  ATH_MSG_VERBOSE("Phimin="<<phimin<<" Phimax="<<phimax<<" shift="<<shift);
1011 
1012  //protection for boundary at pi,-pi
1013  if(phimin<-M_PI_2 && phimax>M_PI_2){
1014  shift=3.*M_PI_4;
1015  ATH_MSG_VERBOSE("Boundary between pi and -pi!!! use the following shift: "<<shift);
1016  }
1017 
1018  //correct the phi values
1019 
1020  for(int i=0;i<count;i++){
1021  double orig=event_data.m_a_phi[i];
1022  double corr=orig-shift;
1023 
1024  if (corr > M_PI) corr = std::fmod(corr+M_PI,2.*M_PI)-M_PI;
1025  else if(corr <-M_PI) corr = std::fmod(corr-M_PI,2.*M_PI)+M_PI;
1026 
1027  event_data.m_a_phi[i]=corr;
1028  event_data.m_a_tan[i]=std::tan(corr);
1029  const auto cosCorr{std::cos(corr)};
1030  event_data.m_a_tan_err[i]=(1.15/700.)/(cosCorr*cosCorr);
1031  }
1032 
1033 
1034  fit=perform_fit(count, event_data);
1035  if(!fit) return;
1036 
1037  //add the ones from the noise list
1038  lit=event_data.m_noiseHits.begin();
1039  litE=event_data.m_noiseHits.end();
1040 
1041  for(;lit!=litE;++lit){
1042 
1043  //don't add hits that really look like noise
1044 
1045  int straw = m_trtid->straw((*lit)->identify());
1046  const Amg::Vector3D& sc = (*lit)->detectorElement()->strawCenter(straw);
1047 
1048  double z=sc.z();
1049  double phi=sc.phi();
1050  double fitted_phi=fit->Eval(sc.z(),0.,0.);
1051  fitted_phi+=shift;
1052 
1053  if (fitted_phi > M_PI) fitted_phi = std::fmod(fitted_phi+M_PI,2.*M_PI)-M_PI;
1054  else if(fitted_phi <-M_PI) fitted_phi = std::fmod(fitted_phi-M_PI,2.*M_PI)+M_PI;
1055 
1056  //only look into the same endcap for noise hits
1057  if(z*event_data.m_a_z[0]<0) continue;
1058 
1059  if(std::abs(phidiff(fitted_phi,phi))<m_scaleTubeNoise*4./800.){
1060  vit=seed->begin();
1061  vitE=seed->end();
1062  bool new_hit=true;
1063  for(;vit!=vitE && new_hit;++vit){
1064  if((*vit)==(*lit)){
1065  new_hit=false;
1066  }
1067  }
1068  if(new_hit){
1069  if(sc.z()>zmin-50 && sc.z()<zmax+50){
1070  ATH_MSG_VERBOSE("\t\t noise hit matched! fitted_phi="<<fitted_phi<<" z=" <<sc.z());
1071  seed->push_back(*lit);
1072  }else{
1073  ATH_MSG_VERBOSE("\t\t noise hit matched but too far away! fitted_phi="<<fitted_phi<<" z=" <<sc.z());
1074  }
1075  }
1076  }
1077  }
1078 
1079  //first: sort along y
1080  std::sort(seed->begin(),seed->end(), CompareDCy);
1081 
1082  //check z-coordinate of first and last hit
1083  Amg::Vector3D firststraw=((*seed)[0]->detectorElement()->strawCenter( m_trtid->straw((*seed)[0]->identify()) ));
1084  Amg::Vector3D laststraw=((*seed)[seed->size()-1]->detectorElement()->strawCenter( m_trtid->straw((*seed)[seed->size()-1]->identify()) ));
1085  z1=firststraw.z();
1086  double z2=laststraw.z();
1087  double yfirst=firststraw.y();
1088  double ylast=laststraw.y();
1089 
1090  ATH_MSG_VERBOSE("zfirst="<<z1<<" zlast="<<z2);
1091 
1092  double Theta=0;
1093  int state=0;
1094 
1095  //sort again, but this time with the correct ordering
1096  if (std::abs(yfirst-ylast)>50){
1097  if(z1>z2) {
1098  std::sort(seed->begin(),seed->end(), CompareDCzreverse);
1099  }else{
1100  std::sort(seed->begin(),seed->end(), CompareDCz);
1101  }
1102  }
1103  else {
1104  if ((yfirst>0 && z1<0) || (yfirst<0 && z1>0)) std::sort(seed->begin(),seed->end(), CompareDCz);
1105  else std::sort(seed->begin(),seed->end(), CompareDCzreverse);
1106  }
1107  firststraw=(*seed)[0]->detectorElement()->strawCenter( m_trtid->straw((*seed)[0]->identify()) );
1108  laststraw=(*seed)[seed->size()-1]->detectorElement()->strawCenter( m_trtid->straw((*seed)[seed->size()-1]->identify()) );
1109  z1=firststraw.z();
1110  z2=laststraw.z();
1111 
1112 
1113  if(z1>z2) {
1114  Theta=M_PI-std::atan2(400.,std::abs(z1-z2));
1115  state=2;
1116  }else{
1117  Theta=std::atan2(400.,std::abs(z1-z2));
1118  state=1;
1119  }
1120 
1121  double globaly=((*seed)[0]->detectorElement()->strawCenter( m_trtid->straw((*seed)[0]->identify()) )).y();
1122  double firstphi=((*seed)[0]->detectorElement()->strawCenter( m_trtid->straw((*seed)[0]->identify()) )).phi();
1123 
1124 
1125  ATH_MSG_VERBOSE("Number of tube hits matching straight line: "<<seed->size());
1126 
1127 
1128  //estimate Segment parameters from first and last hit
1129 
1130  const Amg::Vector3D& sc_first = ((*seed)[0]->detectorElement()->strawCenter( m_trtid->straw((*seed)[0]->identify()) ));
1131  const Amg::Vector3D& sc_last = ((*seed)[seed->size()-1]->detectorElement()->strawCenter( m_trtid->straw((*seed)[seed->size()-1]->identify()) ));
1132 
1133 
1134  double tx1,tx2,ty1,ty2;
1135 
1136  tx1=1050*std::cos(sc_first.phi());
1137  ty1=1050*std::sin(sc_first.phi());
1138 
1139  tx2=650*std::cos(sc_last.phi());
1140  ty2=650*std::sin(sc_last.phi());
1141 
1142  double tphi=std::atan2(ty2-ty1,tx2-tx1);
1143 
1144 
1145  ATH_MSG_VERBOSE("First hit: "<<sc_first<<" \nLast hit: "<<sc_last);
1146 
1147 
1148  ATH_MSG_VERBOSE(" (x1,y1) = ("<<tx1<<","<<ty1<<")");
1149  ATH_MSG_VERBOSE(" (x2,y2) = ("<<tx2<<","<<ty2<<")");
1150 
1151 
1152 
1153  //correct phi to point downwards
1154  if(tphi>0)
1155  tphi-=M_PI;
1156 
1157  //make sure that Theta is positive and less than Pi!
1158 
1159  while(Theta<0)
1160  Theta+=M_PI;
1161 
1162  while(Theta>M_PI)
1163  Theta-=M_PI;
1164 
1165  ATH_MSG_VERBOSE(" tphi="<<tphi);
1166 
1167  ATH_MSG_VERBOSE("globaly = "<<globaly<<" phi="<<firstphi<<" theta="<<Theta<<" --> state = "<<state);
1168 
1169 
1170  vit=seed->begin();
1171  vitE=seed->end();
1172 
1173  count=0;
1174  for(;vit!=vitE;++vit){
1175  count++;
1176  int straw = m_trtid->straw((*vit)->identify());
1177  const Amg::Vector3D& sc = (*vit)->detectorElement()->strawCenter(straw);
1178  ATH_MSG_VERBOSE("Hit "<<count<<" z="<<sc.z()<<" phi="<<sc.phi()<<" y="<<sc.y());
1179  }
1180 
1181 
1182  if(m_useDriftTime){
1183 
1184  ATH_MSG_VERBOSE("drifttime should be used!!!");
1185 
1186  //refit the seed but this time including the drift time information
1187 
1188  //take the left-rigfht assignment from the tube fit and then fit again
1189  count=0;
1190 
1191  vit=seed->begin();
1192  vitE=seed->end();
1193 
1194  for(;vit!=vitE;++vit){
1195  int straw = m_trtid->straw((*vit)->identify());
1196  const Amg::Vector3D& sc = (*vit)->detectorElement()->strawCenter(straw);
1197 
1198  double fitted_phi=fit->Eval(sc.z(),0.,0.);
1199  fitted_phi+=shift;
1200 
1201  if (fitted_phi > M_PI) fitted_phi = std::fmod(fitted_phi+M_PI,2.*M_PI)-M_PI;
1202  else if(fitted_phi <-M_PI) fitted_phi = std::fmod(fitted_phi-M_PI,2.*M_PI)+M_PI;
1203 
1204  int sign=1;
1205  if(fitted_phi<sc.phi()) sign=-1;
1206 
1207 
1208  double driftr = (*vit)->localPosition()(Trk::driftRadius);
1209  double drifte = 2*std::sqrt((*vit)->localCovariance()(0,0));
1210 
1211  double straw_r=640+400./std::abs(z2-z1)*std::abs(sc.z()-z1);
1212 
1213  double dphi=sign*driftr/straw_r;
1214 
1215 
1216  event_data.m_a_z[count]=sc.z();
1217  event_data.m_a_phi[count]=sc.phi()+dphi;
1218  event_data.m_a_phi_err[count]=drifte/straw_r;
1219 
1220  event_data.m_a_tan[count]=std::tan(event_data.m_a_phi[count]-shift);
1221  const auto cosPhiMinShift{std::cos(event_data.m_a_phi[count]-shift)};
1222  event_data.m_a_tan_err[count]=(event_data.m_a_phi_err[count])/( cosPhiMinShift
1223  * cosPhiMinShift);
1224 
1225  event_data.m_a_z_err[count]=0.;
1226 
1227  ATH_MSG_VERBOSE(count<<" z="<<event_data.m_a_z[count]<<" phi="<<event_data.m_a_phi[count]<<" +- "<< event_data.m_a_phi_err[count]);
1228  count++;
1229  }
1230 
1231  ATH_MSG_VERBOSE("Number of hits in first fit (driftradius): "<<count);
1232 
1233  fit=perform_fit(count,event_data);
1234  if(!fit) return;
1235 
1236 
1237  //check if hits are matching
1238  vit=seed->begin();
1239  vitE=seed->end();
1240 
1241  count=0;
1242  for(;vit!=vitE;++vit){
1243  int straw = m_trtid->straw((*vit)->identify());
1244  const Amg::Vector3D& sc = (*vit)->detectorElement()->strawCenter(straw);
1245  double fitted_phi=fit->Eval(sc.z(),0.,0.);
1246  fitted_phi+=shift;
1247 
1248  double driftr = (*vit)->localPosition()(Trk::driftRadius);
1249  double drifte = 2*std::sqrt((*vit)->localCovariance()(0,0));
1250  int sign=1;
1251 
1252  if(fitted_phi<sc.phi()) sign=-1;
1253 
1254  double straw_r=640+400./std::abs(z2-z1)*std::abs(sc.z()-z1);
1255  double dphi=sign*driftr/straw_r;
1256 
1257  if(count>500){
1258  return; // a seed cannot contain that many hits
1259  }
1260 
1261  if (msgLvl(MSG::VERBOSE)) msg()<<"z="<<sc.z()<<" phi="<<sc.phi()<<" fitted_phi = "<<fitted_phi<<endmsg;
1262  if(std::abs(phidiff(fitted_phi,sc.phi()-dphi)) < m_scaleFactorDrift* drifte/straw_r){
1263  if (msgLvl(MSG::VERBOSE)) msg()<<"\t\t matched!!!"<<endmsg;
1264 
1265  event_data.m_a_z[count]=sc.z();
1266  event_data.m_a_phi[count]=sc.phi()+dphi;
1267  event_data.m_a_phi_err[count]=drifte/straw_r;
1268 
1269  event_data.m_a_tan[count]=std::tan(event_data.m_a_phi[count]-shift);
1270  const auto cosPhiMinShift{ std::cos(event_data.m_a_phi[count]-shift)};
1271  event_data.m_a_tan_err[count]=(event_data.m_a_phi_err[count])/( cosPhiMinShift
1272  *cosPhiMinShift);
1273 
1274  event_data.m_a_z_err[count]=0.;
1275  count++;
1276 
1277  }
1278  }
1279 
1280  //refit
1281 
1282  ATH_MSG_VERBOSE("Number of hits in second fit (driftradius): "<<count);
1283 
1284  if(count>4){
1285  fit=perform_fit(count,event_data);
1286  if(!fit) return;
1287  }
1288 
1289  vit=seed->begin();
1290  vitE=seed->end();
1291 
1292  count=0;
1293  for(;vit!=vitE;++vit){
1294  int straw = m_trtid->straw((*vit)->identify());
1295  const Amg::Vector3D& sc = (*vit)->detectorElement()->strawCenter(straw);
1296 
1297  double fitted_phi=fit->Eval(sc.z(),0.,0.);
1298  fitted_phi+=shift;
1299 
1300  if (fitted_phi > M_PI) fitted_phi = std::fmod(fitted_phi+M_PI,2.*M_PI)-M_PI;
1301  else if(fitted_phi <-M_PI) fitted_phi = std::fmod(fitted_phi-M_PI,2.*M_PI)+M_PI;
1302 
1303  double driftr = (*vit)->localPosition()(Trk::driftRadius);
1304  double drifte = 2*std::sqrt((*vit)->localCovariance()(0,0));
1305  int sign=1;
1306 
1307  if(fitted_phi<sc.phi()) sign=-1;
1308 
1309  double straw_r=640+400./std::abs(z2-z1)*std::abs(sc.z()-z1);
1310  double dphi=sign*driftr/straw_r;
1311 
1312 
1313  ATH_MSG_VERBOSE("z="<<sc.z()<<" phi="<<sc.phi()<<" fitted_phi = "<<fitted_phi);
1314  if(std::abs(phidiff(fitted_phi,sc.phi()-dphi)) < m_scaleFactorDrift* drifte/straw_r){
1315  ATH_MSG_VERBOSE("\t\t matched!!!");
1316  count++;
1317  }
1318  }
1319 
1320  ATH_MSG_VERBOSE("Number of hits matched after second fit: "<<count);
1321 
1322  }
1323 
1324 
1325  //create the segment
1326 
1327 
1328 
1329  if(count<m_minDCSeed) return; //too short segments don't make sense
1330 
1331  if(count>=400) return; //too long segments don't make sense
1332 
1333 
1334 
1335  // RIOonTrack production
1336  //
1338 
1339  vit=seed->begin();
1340  vitE=seed->end();
1341 
1342  double chi2=0.;
1343 
1344  double initial_r=-10.;
1345  double initial_locz=0.;
1346 
1347  count=0;
1348  for(;vit!=vitE;++vit){
1349  const Trk::StraightLineSurface* line = static_cast<const Trk::StraightLineSurface*>
1350  (&((*vit)->detectorElement())->surface( (*vit)->identify()));
1351 
1352 
1353  int straw = m_trtid->straw((*vit)->identify());
1354  const Amg::Vector3D& sc = (*vit)->detectorElement()->strawCenter(straw);
1355 
1356  double z=sc.z();
1357  // double phi=sc.phi();
1358 
1359  double locz=0.;
1360 
1361  if(std::abs(z2-z1)>0.000001){
1362  if(state==1){
1363  locz=400./std::abs(z2-z1)*std::abs(z-z1)-200.;
1364  }else{
1365  locz=200.-400./std::abs(z2-z1)*std::abs(z-z1);
1366  }
1367  }
1368  double fitted_phi=fit->Eval(z,0.,0.);
1369  fitted_phi+=shift;
1370 
1371  if (fitted_phi > M_PI) fitted_phi = std::fmod(fitted_phi+M_PI,2.*M_PI)-M_PI;
1372  else if(fitted_phi <-M_PI) fitted_phi = std::fmod(fitted_phi-M_PI,2.*M_PI)+M_PI;
1373 
1374  double fitted_r=(phidiff(fitted_phi,sc.phi()))*(840+locz);
1375  double temp_phi=fitted_phi;
1376 
1377  if(initial_r==-10. && std::abs(fitted_r)<4.0){
1378  initial_r=fitted_r;
1379  initial_locz=locz;
1380  }
1381 
1382  if (temp_phi > M_PI) temp_phi = std::fmod(temp_phi+M_PI,2.*M_PI)-M_PI;
1383  else if(temp_phi <-M_PI) temp_phi = std::fmod(temp_phi-M_PI,2.*M_PI)+M_PI;
1384 
1385  ATH_MSG_VERBOSE(count<<" fitted_r = "<<fitted_r<<" locz="<<locz<<" temp_phi="<<temp_phi);
1386 
1387 
1388  fitted_r*=-1.0;
1389 
1390 
1391  temp_phi=firstphi;
1392 
1393  const Trk::AtaStraightLine Tp(fitted_r,locz,tphi,Theta,.000000001,*line);
1394 
1395  //decide if drifttime should be used
1396 
1397 
1398 
1399 
1400  bool useDrift=false;
1401 
1402  if(m_useDriftTime){
1403  double driftr = (*vit)->localPosition()(Trk::driftRadius);
1404  double drifte = 2*std::sqrt((*vit)->localCovariance()(0,0));
1405  int sign=1;
1406 
1407  if(fitted_phi<sc.phi()) sign=-1;
1408 
1409  double straw_r=640+400./std::abs(z2-z1)*std::abs(sc.z()-z1);
1410  double dphi=sign*driftr/straw_r;
1411 
1412  if(std::abs(phidiff(fitted_phi,sc.phi()-dphi)) < 3* drifte/straw_r){
1413  useDrift=true;
1414  chi2+=(std::abs(fitted_r)-std::abs(driftr))*(std::abs(fitted_r)-std::abs(driftr))/(drifte*drifte);
1415  }
1416 
1417  }
1418 
1419 
1420  if(useDrift){
1421  ATH_MSG_VERBOSE("RIO using drift time!");
1422  rio.push_back(m_riomakerD->correct(*(*vit),Tp, Gaudi::Hive::currentContext()));
1423  }else{
1424  ATH_MSG_VERBOSE("RIO without using drift time!");
1425  chi2+=(fitted_r/1.15)*(fitted_r/1.15); // no drift time used
1426  ATH_MSG_VERBOSE(count<<"\t\t chi2 contribution: "<<(fitted_r/1.15)*(fitted_r/1.15));
1427  rio.push_back(m_riomakerN->correct(*(*vit),Tp, Gaudi::Hive::currentContext()));
1428  }
1429 
1430  count++;
1431 
1432  //add a pseudomeasurement for the first and the last hit constraining loc_z
1433  if(count==1 || (size_t)count==seed->size()){
1436  Amg::MatrixX cov(1,1);
1437  cov<<1.;
1438 
1439  //create new surface
1440  Amg::Vector3D C = line->transform().translation();
1441 
1442  if(state==2 || state==3){
1443  C[2]-=1.;
1444  }else{
1445  C[2]+=1.;
1446  }
1447  Amg::Transform3D T = Amg::Transform3D(line->transform().rotation()*Amg::Translation3D(C));
1449 
1450 
1452  std::move(par),
1453  std::move(cov),
1454  *surface);
1455 
1456  delete surface;
1457 
1458  rio.push_back(pseudo);
1459 
1460  }
1461  }
1462 
1463 
1464  //Track Segment production
1465 
1466  Trk::FitQuality * fqu = new Trk::FitQuality(chi2,count-2);
1467  const Trk::Surface * sur = &((*seed)[0]->detectorElement())->surface((*seed)[0]->identify());
1468 
1469 
1470  //phi should always be negative!
1471 
1472  if(firstphi>0) firstphi=-firstphi;
1473 
1474 
1475  Trk::DefinedParameter dp0(initial_r,Trk::locR);
1476  Trk::DefinedParameter dp1(initial_locz,Trk::locZ);
1477  Trk::DefinedParameter dp2(tphi,Trk::phi);
1478  Trk::DefinedParameter dp3(Theta,Trk::theta);
1479  Trk::DefinedParameter dp4(0.00002,Trk::qOverP);
1480 
1481  std::array<Trk::DefinedParameter,5> defPar = {dp0,dp1,dp2,dp3,dp4};
1482 
1483  Trk::LocalParameters par(defPar);
1484 
1485 
1486  ATH_MSG_VERBOSE("Track parameters from segment:"<<par);
1487 
1488  double universal=1.15;
1489 
1490 
1491  Amg::MatrixX cov(5,5);
1492  cov<<
1493  universal*universal, 0., 0., 0., 0.,
1494  0. , 160000./12., 0., 0., 0.,
1495  0. , 0., 0.1, 0., 0.,
1496  0. , 0., 0., 1., 0.,
1497  0. , 0., 0., 0., 1.;
1498  Trk::TrackSegment* segment = new Trk::TrackSegment(
1499  std::move(par), std::move(cov), sur, std::move(rio), fqu, Trk::Segment::TRT_SegmentMaker);
1500 
1501  //add segment to list of segments
1502 
1503  ATH_MSG_VERBOSE("Add segment to list");
1504  event_data.m_segments.push_back(segment);
1505 
1506 
1507 }
1508 
1509 
1510 
1512 // Pseudo iterator
1514 
1516 {
1519 
1520  if(event_data.m_segiterator!=event_data.m_segments.end()) return (*event_data.m_segiterator++);
1521  return nullptr;
1522 }
1523 
1525 // Dumps relevant information into the MsgStream
1527 
1529 {
1530  return out;
1531 }
1532 
1533 
1535 // Dumps relevant information into the ostream
1537 
1538 std::ostream& InDet::TRT_TrackSegmentsMaker_ECcosmics::dump( std::ostream& out ) const
1539 {
1540  return out;
1541 }
1542 
1543 
1545 // retrieve Hits from StoreGate and sort into noise/good hits lists
1547 
1549 {
1550 
1551  event_data.m_noiseHits.clear();
1552  event_data.m_goodHits.clear();
1553 
1554 
1556  if (not trtcontainer.isValid()) {
1557  ATH_MSG_DEBUG("Could not get TRT_DriftCircleContainer");
1558  return;
1559  }
1560 
1561  SG::ReadHandle<Trk::PRDtoTrackMap> prd_to_track_map;
1562  const Trk::PRDtoTrackMap *prd_to_track_map_cptr=nullptr;
1563  if (!m_prdToTrackMap.key().empty()) {
1565  if (!prd_to_track_map.isValid()) {
1566  ATH_MSG_ERROR("Failed to read PRD to track association map: " << m_prdToTrackMap );
1567  }
1568  prd_to_track_map_cptr = prd_to_track_map.cptr();
1569  }
1570 
1571  const InDet::TRT_DriftCircleContainer* mjo_trtcontainer = trtcontainer.get();
1572  if (!mjo_trtcontainer) return;
1573 
1574  InDet::TRT_DriftCircleContainer::const_iterator
1575  w = trtcontainer->begin(),we = trtcontainer->end();
1576  for(; w!=we; ++w) {
1577 
1578  Identifier ID = (*w)->identify();
1579  if(std::abs(m_trtid->barrel_ec(ID))!=2) continue; // only endcaps please!!!
1580 
1581  InDet::TRT_DriftCircleCollection::const_iterator
1582  c = (*w)->begin(), ce = (*w)->end();
1583 
1584  for(; c!=ce; ++c) {
1585 
1586  if(prd_to_track_map_cptr && prd_to_track_map_cptr->isUsed(*(*c))) continue; //don't use hits that have already been used
1587 
1588  if( (*c)->isNoise() || (*c)->timeOverThreshold()<m_cutToTLoose) {
1589  event_data.m_noiseHits.push_back(*c);
1590  }else{
1591  event_data.m_goodHits.push_back(*c);
1592  }
1593 
1594  }
1595  }
1596 
1597  ATH_MSG_DEBUG("good hits in endcap: "<<event_data.m_goodHits.size());
1598  ATH_MSG_DEBUG("noise hits in endcap: "<<event_data.m_noiseHits.size());
1599 
1600 
1601  if(event_data.m_goodHits.size()>(size_t)m_hitLimit){
1602  // this event is too busy ...
1603  ATH_MSG_DEBUG("This event has more than "<<m_hitLimit<<" good hits. Aborting segment finding ...");
1604  event_data.m_goodHits.clear();
1605  event_data.m_noiseHits.clear();
1606  return;
1607  }
1608 
1609  //move isolated hits from the good hits vector to the noise hits vector
1610  //
1611  auto it=event_data.m_goodHits.begin();
1612  auto itE=event_data.m_goodHits.end();
1613  auto it_remove(it);
1614  bool remove=false;
1615  //
1616  const double dPhiLimit{0.03};
1617  const double dzLimit{31.};
1618  for(;it!=itE;++it){
1619  if(remove){
1620  event_data.m_goodHits.erase(it_remove);
1621  remove=false;
1622  }
1623  const bool accept=accepted(it, event_data.m_goodHits, dPhiLimit, dzLimit);
1624  if(!accept){
1625  event_data.m_noiseHits.push_back(*it);
1626  it_remove=it;
1627  remove=true;
1628  }
1629  }
1630  if(remove){
1631  event_data.m_goodHits.erase(it_remove);
1632  remove=false;
1633  }
1634 
1635  //2nd pass through good hits with increased ToT cut
1636 
1637  it=event_data.m_goodHits.begin();
1638  itE=event_data.m_goodHits.end();
1639 
1640  remove=false;
1641 
1642  for(;it!=itE;++it){
1643 
1644  if(remove){
1645  event_data.m_goodHits.erase(it_remove);
1646  remove=false;
1647  }
1648 
1649  if((*it)->timeOverThreshold()<m_cutToTTight || (*it)->timeOverThreshold()>m_cutToTUpper){
1650  event_data.m_noiseHits.push_back(*it);
1651  it_remove=it;
1652  remove=true;
1653  }
1654  }
1655  if(remove){
1656  event_data.m_goodHits.erase(it_remove);
1657  remove=false;
1658  }
1659 
1660 
1661  //2nd pass through good hits with loosened isolation criteria
1662 
1663  it=event_data.m_goodHits.begin();
1664  itE=event_data.m_goodHits.end();
1665 
1666  remove=false;
1667 
1668  for(;it!=itE;++it){
1669  if(remove){
1670  event_data.m_goodHits.erase(it_remove);
1671  remove=false;
1672  }
1673  const bool accept=accepted(it, event_data.m_goodHits, 0.25, 200.);
1674  if(!accept){
1675  ATH_MSG_DEBUG("Removing hit in 2nd pass isolation");
1676  event_data.m_noiseHits.push_back(*it);
1677  it_remove=it;
1678  remove=true;
1679  }
1680  }
1681 
1682  if(remove){
1683  event_data.m_goodHits.erase(it_remove);
1684  remove=false;
1685  }
1686 
1687  ATH_MSG_DEBUG("good hits in endcap: "<<event_data.m_goodHits.size());
1688  ATH_MSG_DEBUG("noise hits in endcap: "<<event_data.m_noiseHits.size());
1689 
1690 }
1691 
1692 bool
1695  std::list<const InDet::TRT_DriftCircle*> & container,
1696  double dPhiLimit, double dzLimit) const{
1697  //
1698  const auto id = (*it)->identify();
1699  const auto ns = m_trtid->straw(id);
1700  const auto endcap= m_trtid->barrel_ec(id);
1701  const auto wheel = std::abs(m_trtid->layer_or_wheel(id));
1702  const Amg::Vector3D& sc = (*it)->detectorElement()->strawCenter(ns);
1703  //
1704  bool accept{false};
1705  for(auto it2=container.begin();it2!=container.end();++it2){
1706  if(it==it2) continue;
1707  Identifier id2 = (*it2)->identify();
1708  int endcap2=m_trtid->barrel_ec(id2);
1709  int wheel2=std::abs(m_trtid->layer_or_wheel(id2));
1710  //only look inside the same wheel
1711  if(endcap!=endcap2 || wheel2!=wheel) continue;
1712  int ns2 = m_trtid->straw(id2);
1713  const Amg::Vector3D& sc2 = (*it2)->detectorElement()->strawCenter(ns2);
1714  double dz=sc.z()-sc2.z();
1715  double dphi=phidiff(sc.phi(),sc2.phi());
1716  dphi*=300.0; // scale factor for dphi to get equal weight
1717  dz=std::abs(dz);
1718  dphi=std::abs(dphi/300.0);
1719  if(dphi<dPhiLimit and dz<dzLimit){
1720  accept=true;
1721  //break was not in original code...
1722  break; //...but no need to continue once accept has been set
1723  }
1724  } //end inner loop
1725  return accept;
1726 }
1727 
1729 // Perform the actual track fit to the coordinates
1731 
1733 
1736 {
1737  // @TODO not thread-safe enough! need a globak root lock !
1738  std::lock_guard<std::mutex> lock(s_fitMutex);
1739  TVirtualFitter::SetMaxIterations(100000);
1740 
1741  RootUtils::WithRootErrorHandler hand ([] (int, bool, const char*, const char*) { return false; });
1742 
1743 
1744  event_data.m_fitf_ztanphi->SetParameter(0,0.);
1745  event_data.m_fitf_ztanphi->SetParameter(1,0.);
1746  event_data.m_fitf_ztanphi->SetParameter(2,0.);
1747 
1748  TGraphErrors *gre=new TGraphErrors(count,event_data.m_a_z,event_data.m_a_tan,event_data.m_a_z_err,event_data.m_a_tan_err);
1749  int fitresult1=gre->Fit(event_data.m_fitf_ztanphi,"Q");
1750 
1751  ATH_MSG_VERBOSE("Fit result (ztanphi): a0="<<event_data.m_fitf_ztanphi->GetParameter(0)
1752  <<" a1="<<event_data.m_fitf_ztanphi->GetParameter(1)<<" a2="
1753  <<event_data.m_fitf_ztanphi->GetParameter(2)<<" fitresult="<<fitresult1);
1754 
1755  //copy over the parameters
1756  event_data.m_fitf_zphi->SetParameter(0,event_data.m_fitf_ztanphi->GetParameter(0));
1757  event_data.m_fitf_zphi->SetParameter(1,event_data.m_fitf_ztanphi->GetParameter(1));
1758  event_data.m_fitf_zphi->SetParameter(2,event_data.m_fitf_ztanphi->GetParameter(2));
1759 
1760  delete gre;
1761 
1762  gre=new TGraphErrors(count,event_data.m_a_z,event_data.m_a_phi,event_data.m_a_z_err,event_data.m_a_phi_err);
1763  int fitresult2=gre->Fit(event_data.m_fitf_zphi_approx,"Q");
1764 
1765 
1766  ATH_MSG_VERBOSE( "Fit result (zphi): a0="<< event_data.m_fitf_zphi_approx->GetParameter(0)
1767  <<" a1="<< event_data.m_fitf_zphi_approx->GetParameter(1)<<" a2="
1768  << event_data.m_fitf_zphi_approx->GetParameter(2)<<" fitresult="<<fitresult2);
1769 
1770  double p1=event_data.m_fitf_ztanphi->GetProb();
1771  double p2=event_data.m_fitf_zphi_approx->GetProb();
1772 
1773  ATH_MSG_VERBOSE("tanphi prob: "<<p1<<" pol2 prob : "<<p2);
1774 
1775  delete gre;
1776 
1777 
1778  if(fitresult1!=0 && fitresult2!=0) return nullptr;
1779  if(fitresult1!=0 && fitresult2==0) return event_data.m_fitf_zphi_approx;
1780  if(fitresult1==0 && fitresult2!=0) return event_data.m_fitf_zphi;
1781 
1782 
1783  int match_tan=0;
1784  int match_phi=0;
1785  for(int i=0;i<count;i++){
1786  double phi1=event_data.m_fitf_zphi->Eval(event_data.m_a_z[i]);
1787  double phi2=event_data.m_fitf_zphi_approx->Eval(event_data.m_a_z[i]);
1788 
1789  if(std::abs(phi1-event_data.m_a_phi[i])<2*event_data.m_a_phi_err[i])
1790  match_tan++;
1791 
1792  if(std::abs(phi2-event_data.m_a_phi[i])<2*event_data.m_a_phi_err[i])
1793  match_phi++;
1794 
1795  }
1796 
1797 
1798  ATH_MSG_VERBOSE("Number of hits matching this fit: tan="<<match_tan<<" pol2="<<match_phi);
1799 
1800  if(match_tan>match_phi){
1801  return event_data.m_fitf_zphi;
1802  }else if(match_tan<match_phi){
1803  return event_data.m_fitf_zphi_approx;
1804  }
1805 
1806  if(p1>p2){
1807  return event_data.m_fitf_zphi;
1808  }else{
1809  return event_data.m_fitf_zphi_approx;
1810  }
1811 
1812 }
1813 
1815 // Provide the proper subtraction of two phi values
1817 
1818 
1819 // @TODO unusued
1821  std::vector<const InDet::TRT_DriftCircle*> *seed) const
1822 {
1823 
1824  double mean=0,var=0;
1825  double meanz=0,varz=0;
1826 
1828 
1829  vit=seed->begin();
1830  vitE=seed->end();
1831 
1832  double dcz[500];
1833  int count=0;
1834  int index=-1;
1835  for(;vit!=vitE;++vit){
1836  int straw = m_trtid->straw((*vit)->identify());
1837  const Amg::Vector3D& sc = (*vit)->detectorElement()->strawCenter(straw);
1838 
1839  if(dc==*vit) index=count;
1840  dcz[count++]=sc.z();
1841 
1842  meanz+=sc.z();
1843  varz+=sc.z()*sc.z();
1844  }
1845 
1846  if(count < 2) return true;
1847 
1848  varz=(count*varz-meanz*meanz);
1849  varz/=(double)(count*(count-1));
1850 
1851  meanz/=(double)count;
1852 
1853  varz=std::sqrt(varz);
1854 
1855  double zmin_sel=100000;
1856 
1857  for(int i=0;i<count;i++){
1858  double zmin=10000;
1859 
1860  if(i-1>=0)
1861  if(std::abs(dcz[i]-dcz[i-1])<zmin) zmin=std::abs(dcz[i]-dcz[i-1]);
1862  if(i+1<count)
1863  if(std::abs(dcz[i]-dcz[i+1])<zmin) zmin=std::abs(dcz[i]-dcz[i+1]);
1864 
1865  if(i==index)
1866  zmin_sel=zmin;
1867 
1868  mean+=zmin;
1869  var+=zmin*zmin;
1870  }
1871 
1872  var=(count*var-mean*mean);
1873  var/=(double)(count*(count-1));
1874 
1875  mean/=(double)count;
1876 
1877  var=std::sqrt(var);
1878 
1879  if(var<6) var=6;
1880 
1881  if(std::abs(zmin_sel-mean)>2*var){// || std::abs(dcz[index]-meanz)>2*varz){
1882  if(index>=0) {
1883  ATH_MSG_VERBOSE("Hit is suspicious, remove it! "<<std::abs(zmin_sel-mean)<<" , "<<2*var<<" -> "<<zmin_sel<< " : "<<dcz[index]<<" <-> "<<meanz<<" ("<<varz<<")");
1884  }
1885  return true;
1886  }else{
1887  if(index>=0) {
1888  ATH_MSG_VERBOSE("Hit seems to be ok: "<<std::abs(zmin_sel-mean)<<" < "<<2*var<<" && "<<std::abs(dcz[index]-meanz)<<" < "<<1.5*varz);
1889  }
1890  }
1891  return false;
1892 }
python.PyKernel.retrieve
def retrieve(aClass, aKey=None)
Definition: PyKernel.py:110
xAOD::iterator
JetConstituentVector::iterator iterator
Definition: JetConstituentVector.cxx:68
fitf_zphi_approx
Double_t fitf_zphi_approx(const Double_t *x, const Double_t *par)
Definition: TRT_TrackSegmentsMaker_ECcosmics.cxx:66
Trk::LocalParameters
Definition: LocalParameters.h:98
TRT_TrackSegmentsMaker_ECcosmics.h
beamspotnt.var
var
Definition: bin/beamspotnt.py:1393
TileDCSDataPlotter.dp
dp
Definition: TileDCSDataPlotter.py:842
xAOD::identify
const Identifier & identify(const UncalibratedMeasurement *meas)
Returns the associated identifier from the muon measurement.
Definition: MuonSpectrometer/MuonPhaseII/Event/xAOD/xAODMuonPrepData/Root/UtilFunctions.cxx:95
InDet::TRT_TrackSegmentsMaker_ECcosmics::setFitFunctions
void setFitFunctions(TRT_TrackSegmentsMaker_ECcosmics::EventData &event_data) const
Definition: TRT_TrackSegmentsMaker_ECcosmics.cxx:115
python.tests.PyTestsLib.finalize
def finalize(self)
_info( "content of StoreGate..." ) self.sg.dump()
Definition: PyTestsLib.py:50
ATH_MSG_FATAL
#define ATH_MSG_FATAL(x)
Definition: AthMsgStreamMacros.h:34
TRT::Hit::straw
@ straw
Definition: HitInfo.h:82
InDet::TRT_TrackSegmentsMaker_ECcosmics::EventData::m_goodHits
std::list< const InDet::TRT_DriftCircle * > m_goodHits
List containing potenitally good hits.
Definition: TRT_TrackSegmentsMaker_ECcosmics.h:136
Amg::MatrixX
Eigen::Matrix< double, Eigen::Dynamic, Eigen::Dynamic > MatrixX
Dynamic Matrix - dynamic allocation.
Definition: EventPrimitives.h:27
mean
void mean(std::vector< double > &bins, std::vector< double > &values, const std::vector< std::string > &files, const std::string &histname, const std::string &tplotname, const std::string &label="")
Definition: dependence.cxx:254
InDet::TRT_TrackSegmentsMaker_ECcosmics::perform_fit
TF1 * perform_fit(int count, TRT_TrackSegmentsMaker_ECcosmics::EventData &event_data) const
Perform the fit and return a function that provides the fitted phi information.
Definition: TRT_TrackSegmentsMaker_ECcosmics.cxx:1734
InDet::TRT_TrackSegmentsMaker_ECcosmics::find_seed
bool find_seed(int endcap, int zslice, int sector, TRT_TrackSegmentsMaker_ECcosmics::EventData &event_data) const
Find seed in the given sector/zslice/endcap.
Definition: TRT_TrackSegmentsMaker_ECcosmics.cxx:386
StraightLineSurface.h
phi
Scalar phi() const
phi method
Definition: AmgMatrixBasePlugin.h:67
InDet::TRT_TrackSegmentsMaker_ECcosmics::m_cutToTTight
DoubleProperty m_cutToTTight
Definition: TRT_TrackSegmentsMaker_ECcosmics.h:193
InDet::TRT_TrackSegmentsMaker_ECcosmics::accepted
bool accepted(const std::list< const InDet::TRT_DriftCircle * >::iterator compareIt, std::list< const InDet::TRT_DriftCircle * > &container, double phiLimit, double dzLimit) const
is the hit accepted?
Definition: TRT_TrackSegmentsMaker_ECcosmics.cxx:1693
ID
std::vector< Identifier > ID
Definition: CalibHitIDCheck.h:24
SG::ReadHandle::cptr
const_pointer_type cptr()
Dereference the pointer.
TRT_DetectorManager.h
Surface.h
InDet::TRT_TrackSegmentsMaker_ECcosmics::m_minDCSeed
IntegerProperty m_minDCSeed
Definition: TRT_TrackSegmentsMaker_ECcosmics.h:197
Trk::PRDtoTrackMap
Definition: PRDtoTrackMap.h:17
PixelAthClusterMonAlgCfg.zmin
zmin
Definition: PixelAthClusterMonAlgCfg.py:169
SG::ReadHandle
Definition: StoreGate/StoreGate/ReadHandle.h:67
index
Definition: index.py:1
BeamSpot::mutex
std::mutex mutex
Definition: InDetBeamSpotVertex.cxx:18
max
constexpr double max()
Definition: ap_fixedTest.cxx:33
Trk::ParametersT
Dummy class used to allow special convertors to be called for surfaces owned by a detector element.
Definition: EMErrorDetail.h:25
InDet
Primary Vertex Finder.
Definition: VP1ErrorUtils.h:36
initialize
void initialize()
Definition: run_EoverP.cxx:894
CutsMETMaker::accept
StatusCode accept(const xAOD::Muon *mu)
Definition: CutsMETMaker.cxx:18
InDet::TRT_TrackSegmentsMaker_ECcosmics::is_suspicious
bool is_suspicious(const InDet::TRT_DriftCircle *dc, std::vector< const InDet::TRT_DriftCircle * > *seed) const
checks if a hit that matches the segment looks suspicious (i.e.
Definition: TRT_TrackSegmentsMaker_ECcosmics.cxx:1820
InDet::TRT_TrackSegmentsMaker_ECcosmics::m_cutToTLoose
DoubleProperty m_cutToTLoose
Definition: TRT_TrackSegmentsMaker_ECcosmics.h:191
TRTCalib_cfilter.p1
p1
Definition: TRTCalib_cfilter.py:130
skel.it
it
Definition: skel.GENtoEVGEN.py:407
plotBeamSpotVxVal.cov
cov
Definition: plotBeamSpotVxVal.py:200
python.AthDsoLogger.out
out
Definition: AthDsoLogger.py:70
M_PI
#define M_PI
Definition: ActiveFraction.h:11
InDet::TRT_TrackSegmentsMaker_ECcosmics::next
virtual Trk::TrackSegment * next(InDet::ITRT_TrackSegmentsMaker::IEventData &event_data) const override
Definition: TRT_TrackSegmentsMaker_ECcosmics.cxx:1515
AthCommonMsg< AlgTool >::msgLvl
bool msgLvl(const MSG::Level lvl) const
Definition: AthCommonMsg.h:30
InDet::TRT_TrackSegmentsMaker_ECcosmics::EventData::m_segiterator
std::list< Trk::TrackSegment * >::iterator m_segiterator
Iterator over found segments.
Definition: TRT_TrackSegmentsMaker_ECcosmics.h:143
python.RatesEmulationExample.lock
lock
Definition: RatesEmulationExample.py:148
Trk::locR
@ locR
Definition: ParamDefs.h:44
InDet::TRT_TrackSegmentsMaker_ECcosmics::m_riomakerD
ToolHandle< Trk::IRIO_OnTrackCreator > m_riomakerD
Definition: TRT_TrackSegmentsMaker_ECcosmics.h:175
read_hist_ntuple.t
t
Definition: read_hist_ntuple.py:5
drawFromPickle.cos
cos
Definition: drawFromPickle.py:36
Trk::TrackSegment
Definition: TrackSegment.h:56
ATH_MSG_VERBOSE
#define ATH_MSG_VERBOSE(x)
Definition: AthMsgStreamMacros.h:28
SG::VarHandleKey::key
const std::string & key() const
Return the StoreGate ID for the referenced object.
Definition: AthToolSupport/AsgDataHandles/Root/VarHandleKey.cxx:141
InDet::TRT_TrackSegmentsMaker_ECcosmics::m_scaleFactorDrift
DoubleProperty m_scaleFactorDrift
Definition: TRT_TrackSegmentsMaker_ECcosmics.h:187
x
#define x
dq_defect_bulk_create_defects.line
line
Definition: dq_defect_bulk_create_defects.py:27
InDet::TRT_TrackSegmentsMaker_ECcosmics::find
virtual void find(const EventContext &ctx, InDet::ITRT_TrackSegmentsMaker::IEventData &event_data, InDet::TRT_DetElementLink_xk::TRT_DetElemUsedMap &used) const override
Definition: TRT_TrackSegmentsMaker_ECcosmics.cxx:302
InDet::TRT_TrackSegmentsMaker_ECcosmics::EventData::m_fitf_zphi
TF1 * m_fitf_zphi
analytic function to fit phi vs.
Definition: TRT_TrackSegmentsMaker_ECcosmics.h:155
InDet::TRT_DriftCircle
Definition: TRT_DriftCircle.h:32
XMLtoHeader.count
count
Definition: XMLtoHeader.py:84
makeTRTBarrelCans.y1
tuple y1
Definition: makeTRTBarrelCans.py:15
TruthTest.itE
itE
Definition: TruthTest.py:25
drawFromPickle.atan
atan
Definition: drawFromPickle.py:36
AthenaPoolTestRead.sc
sc
Definition: AthenaPoolTestRead.py:27
InDet::TRT_TrackSegmentsMaker_ECcosmics::EventData::m_sectors
std::list< const InDet::TRT_DriftCircle * > m_sectors[2][20][16]
Divide into two endcaps and each endcap into 16 sectors in phi and 20 in z.
Definition: TRT_TrackSegmentsMaker_ECcosmics.h:139
Trk::DefinedParameter
std::pair< double, ParamDefs > DefinedParameter
Definition: DefinedParameter.h:27
AthCommonDataStore< AthCommonMsg< AlgTool > >::detStore
const ServiceHandle< StoreGateSvc > & detStore() const
The standard StoreGateSvc/DetectorStore Returns (kind of) a pointer to the StoreGateSvc.
Definition: AthCommonDataStore.h:95
InDet::TRT_TrackSegmentsMaker_ECcosmics::phidiff
static double phidiff(double a, double b)
provide the proper subtraction of two phi values
Definition: TRT_TrackSegmentsMaker_ECcosmics.h:250
InDet::TRT_TrackSegmentsMaker_ECcosmics::m_phaseMode
BooleanProperty m_phaseMode
Definition: TRT_TrackSegmentsMaker_ECcosmics.h:166
Trk::PseudoMeasurementOnTrack
Class to handle pseudo-measurements in fitters and on track objects.
Definition: PseudoMeasurementOnTrack.h:44
PixelModuleFeMask_create_db.remove
string remove
Definition: PixelModuleFeMask_create_db.py:83
TRTCalib_cfilter.p2
p2
Definition: TRTCalib_cfilter.py:131
TRT_ID::straw
int straw(const Identifier &id) const
Definition: TRT_ID.h:896
python.utils.AtlRunQueryDQUtils.p
p
Definition: AtlRunQueryDQUtils.py:209
athena.ps2
ps2
Definition: athena.py:136
ATH_MSG_ERROR
#define ATH_MSG_ERROR(x)
Definition: AthMsgStreamMacros.h:33
Trk::index1
@ index1
Definition: BoundarySurfaceFace.h:48
Trk::locZ
@ locZ
local cylindrical
Definition: ParamDefs.h:42
InDet::TRT_TrackSegmentsMaker_ECcosmics::newEvent
virtual std::unique_ptr< InDet::ITRT_TrackSegmentsMaker::IEventData > newEvent(const EventContext &ctx) const override
Definition: TRT_TrackSegmentsMaker_ECcosmics.cxx:156
InDet::CompareDCy
bool CompareDCy(const InDet::TRT_DriftCircle *x, const InDet::TRT_DriftCircle *y)
Definition: TRT_TrackSegmentsMaker_ECcosmics.cxx:271
id2
HWIdentifier id2
Definition: LArRodBlockPhysicsV0.cxx:562
lumiFormat.i
int i
Definition: lumiFormat.py:85
z
#define z
PixelAthClusterMonAlgCfg.e4
e4
Definition: PixelAthClusterMonAlgCfg.py:332
python.SystemOfUnits.ps
float ps
Definition: SystemOfUnits.py:150
beamspotman.n
n
Definition: beamspotman.py:727
Trk::theta
@ theta
Definition: ParamDefs.h:66
endmsg
#define endmsg
Definition: AnalysisConfig_Ntuple.cxx:63
EL::StatusCode
::StatusCode StatusCode
StatusCode definition for legacy code.
Definition: PhysicsAnalysis/D3PDTools/EventLoop/EventLoop/StatusCode.h:22
SG::ReadHandle::get
const_pointer_type get() const
Dereference the pointer, but don't cache anything.
ATH_MSG_DEBUG
#define ATH_MSG_DEBUG(x)
Definition: AthMsgStreamMacros.h:29
makeTRTBarrelCans.y2
tuple y2
Definition: makeTRTBarrelCans.py:18
Trk::driftRadius
@ driftRadius
trt, straws
Definition: ParamDefs.h:53
InDet::TRT_TrackSegmentsMaker_ECcosmics::finalize
virtual StatusCode finalize() override
Definition: TRT_TrackSegmentsMaker_ECcosmics.cxx:145
InDet::TRT_TrackSegmentsMaker_ECcosmics::endEvent
void endEvent(InDet::ITRT_TrackSegmentsMaker::IEventData &event_data) const override
Definition: TRT_TrackSegmentsMaker_ECcosmics.cxx:248
Amg::Transform3D
Eigen::Affine3d Transform3D
Definition: GeoPrimitives.h:46
InDet::TRT_TrackSegmentsMaker_ECcosmics::m_riomakerN
ToolHandle< Trk::IRIO_OnTrackCreator > m_riomakerN
Definition: TRT_TrackSegmentsMaker_ECcosmics.h:179
chi2
double chi2(TH1 *h0, TH1 *h1)
Definition: comparitor.cxx:525
InDet::TRT_TrackSegmentsMaker_ECcosmics::EventData::m_a_z_err
double m_a_z_err[1000]
Definition: TRT_TrackSegmentsMaker_ECcosmics.h:150
PseudoMeasurementOnTrack.h
PixelAthClusterMonAlgCfg.zmax
zmax
Definition: PixelAthClusterMonAlgCfg.py:169
sign
int sign(int a)
Definition: TRT_StrawNeighbourSvc.h:108
ATH_CHECK
#define ATH_CHECK
Definition: AthCheckMacros.h:40
InDet::TRT_TrackSegmentsMaker_ECcosmics::EventData::m_seeds
std::vector< std::vector< const InDet::TRT_DriftCircle * > * > m_seeds
Vector of seeds.
Definition: TRT_TrackSegmentsMaker_ECcosmics.h:141
InDet::TRT_TrackSegmentsMaker_ECcosmics::create_segment
void create_segment(std::vector< const InDet::TRT_DriftCircle * > *seed, TRT_TrackSegmentsMaker_ECcosmics::EventData &event_data) const
Create segment out of a seed.
Definition: TRT_TrackSegmentsMaker_ECcosmics.cxx:799
hist_file_dump.f
f
Definition: hist_file_dump.py:140
InDet::TRT_TrackSegmentsMaker_ECcosmics::EventData::m_a_phi_err
double m_a_phi_err[1000]
Definition: TRT_TrackSegmentsMaker_ECcosmics.h:147
InDet::TRT_TrackSegmentsMaker_ECcosmics::~TRT_TrackSegmentsMaker_ECcosmics
virtual ~TRT_TrackSegmentsMaker_ECcosmics()
drawFromPickle.tan
tan
Definition: drawFromPickle.py:36
Trk::FitQuality
Class to represent and store fit qualities from track reconstruction in terms of and number of degre...
Definition: FitQuality.h:97
SG::VarHandleKey::initialize
StatusCode initialize(bool used=true)
If this object is used as a property, then this should be called during the initialize phase.
Definition: AthToolSupport/AsgDataHandles/Root/VarHandleKey.cxx:103
TRT_ID::barrel_ec
int barrel_ec(const Identifier &id) const
Values of different levels (failure returns 0)
Definition: TRT_ID.h:860
xAOD::double
double
Definition: CompositeParticle_v1.cxx:159
fitf_zphi
Double_t fitf_zphi(const Double_t *x, const Double_t *par)
Definition: TRT_TrackSegmentsMaker_ECcosmics.cxx:60
InDet::TRT_TrackSegmentsMaker_ECcosmics::evaluate_seed
int evaluate_seed(int endcap, int zslice, int sector, const double *p, TRT_TrackSegmentsMaker_ECcosmics::EventData &event_data) const
Evaluate how many dc match this seed.
Definition: TRT_TrackSegmentsMaker_ECcosmics.cxx:744
DataVector< const Trk::MeasurementBase >
TRT_ID::layer_or_wheel
int layer_or_wheel(const Identifier &id) const
Definition: TRT_ID.h:878
Trk::PRDtoTrackMap::isUsed
bool isUsed(const PrepRawData &prd) const
does this PRD belong to at least one track?
SG::ReadHandle::isValid
virtual bool isValid() override final
Can the handle be successfully dereferenced?
InDet::TRT_TrackSegmentsMaker_ECcosmics::EventData
Definition: TRT_TrackSegmentsMaker_ECcosmics.h:117
MuonValidation_CreateResolutionProfiles.fit
def fit(h, emin, emax)
Definition: MuonValidation_CreateResolutionProfiles.py:69
InDet::TRT_TrackSegmentsMaker_ECcosmics::newRegion
virtual std::unique_ptr< InDet::ITRT_TrackSegmentsMaker::IEventData > newRegion(const EventContext &ctx, const std::vector< IdentifierHash > &) const override
Definition: TRT_TrackSegmentsMaker_ECcosmics.cxx:203
InDet::TRT_DriftCircleContainer
Trk::PrepRawDataContainer< TRT_DriftCircleCollection > TRT_DriftCircleContainer
Definition: TRT_DriftCircleContainer.h:27
TRT_DriftCircleContainer.h
InDet::TRT_TrackSegmentsMaker_ECcosmics::m_cutToTUpper
DoubleProperty m_cutToTUpper
Definition: TRT_TrackSegmentsMaker_ECcosmics.h:195
InDet::TRT_TrackSegmentsMaker_ECcosmics::EventData::m_noiseHits
std::list< const InDet::TRT_DriftCircle * > m_noiseHits
List containing potentially noise hits.
Definition: TRT_TrackSegmentsMaker_ECcosmics.h:135
InDet::TRT_TrackSegmentsMaker_ECcosmics::EventData::m_fitf_ztanphi
TF1 * m_fitf_ztanphi
analytic function to fit tan(phi) vs.
Definition: TRT_TrackSegmentsMaker_ECcosmics.h:154
Trk::index2
@ index2
Definition: BoundarySurfaceFace.h:49
name
std::string name
Definition: Control/AthContainers/Root/debug.cxx:240
createCoolChannelIdFile.par
par
Definition: createCoolChannelIdFile.py:28
RIO_OnTrack.h
RootUtils::WithRootErrorHandler
Run a MT piece of code with an alternate root error handler.
Definition: WithRootErrorHandler.h:56
checkTriggerxAOD.found
found
Definition: checkTriggerxAOD.py:328
InDet::CompareDCz
bool CompareDCz(const InDet::TRT_DriftCircle *x, const InDet::TRT_DriftCircle *y)
Definition: TRT_TrackSegmentsMaker_ECcosmics.cxx:259
Amg::Vector3D
Eigen::Matrix< double, 3, 1 > Vector3D
Definition: GeoPrimitives.h:47
InDet::TRT_TrackSegmentsMaker_ECcosmics::m_hitLimit
IntegerProperty m_hitLimit
Definition: TRT_TrackSegmentsMaker_ECcosmics.h:199
InDet::TRT_TrackSegmentsMaker_ECcosmics::m_prdToTrackMap
SG::ReadHandleKey< Trk::PRDtoTrackMap > m_prdToTrackMap
Definition: TRT_TrackSegmentsMaker_ECcosmics.h:172
InDet::TRT_TrackSegmentsMaker_ECcosmics::EventData::m_a_tan
double m_a_tan[1000]
Definition: TRT_TrackSegmentsMaker_ECcosmics.h:148
WithRootErrorHandler.h
Run a MT piece of code with an alternate root error handler.
fitf_ztanphi
Double_t fitf_ztanphi(const Double_t *x, const Double_t *par)
Definition: TRT_TrackSegmentsMaker_ECcosmics.cxx:54
y
#define y
python.CaloAddPedShiftConfig.int
int
Definition: CaloAddPedShiftConfig.py:45
InDet::TRT_TrackSegmentsMaker_ECcosmics::TRT_TrackSegmentsMaker_ECcosmics
TRT_TrackSegmentsMaker_ECcosmics(const std::string &, const std::string &, const IInterface *)
Constructor with parameters.
Definition: TRT_TrackSegmentsMaker_ECcosmics.cxx:36
InDet::TRT_TrackSegmentsMaker_ECcosmics::initialize
virtual StatusCode initialize() override
Definition: TRT_TrackSegmentsMaker_ECcosmics.cxx:76
InDet::TRT_TrackSegmentsMaker_ECcosmics::EventData::m_a_tan_err
double m_a_tan_err[1000]
Definition: TRT_TrackSegmentsMaker_ECcosmics.h:149
InDet::CompareDCzreverse
bool CompareDCzreverse(const InDet::TRT_DriftCircle *x, const InDet::TRT_DriftCircle *y)
Definition: TRT_TrackSegmentsMaker_ECcosmics.cxx:283
InDet::TRT_TrackSegmentsMaker_ECcosmics::m_trtid
const TRT_ID * m_trtid
Definition: TRT_TrackSegmentsMaker_ECcosmics.h:168
Amg::Translation3D
Eigen::Translation< double, 3 > Translation3D
Definition: GeoPrimitives.h:44
AthCommonMsg< AlgTool >::msg
MsgStream & msg() const
Definition: AthCommonMsg.h:24
Trk::qOverP
@ qOverP
perigee
Definition: ParamDefs.h:67
InDet::TRT_TrackSegmentsMaker_ECcosmics::EventData::m_a_z
double m_a_z[1000]
Definition: TRT_TrackSegmentsMaker_ECcosmics.h:145
InDet::TRT_TrackSegmentsMaker_ECcosmics::EventData::m_fitf_zphi_approx
TF1 * m_fitf_zphi_approx
anpprox function to fit phi vs.
Definition: TRT_TrackSegmentsMaker_ECcosmics.h:158
Trk::MeasurementBaseType::PseudoMeasurementOnTrack
@ PseudoMeasurementOnTrack
Definition: MeasurementBase.h:51
Trk::phi
@ phi
Definition: ParamDefs.h:75
Trk::EventDataBase< EventData, InDet::ITRT_TrackSegmentsMaker::IEventData >::getPrivateEventData
static EventData & getPrivateEventData(InDet::ITRT_TrackSegmentsMaker::IEventData &virt_event_data)
Definition: EventDataBase.h:19
python.Constants.VERBOSE
int VERBOSE
Definition: Control/AthenaCommon/python/Constants.py:13
InDet::TRT_TrackSegmentsMaker_ECcosmics::m_useDriftTime
BooleanProperty m_useDriftTime
Definition: TRT_TrackSegmentsMaker_ECcosmics.h:183
drawFromPickle.sin
sin
Definition: drawFromPickle.py:36
InDet::TRT_TrackSegmentsMaker_ECcosmics::m_scaleTubeNoise
DoubleProperty m_scaleTubeNoise
Definition: TRT_TrackSegmentsMaker_ECcosmics.h:189
ReadHandle.h
Handle class for reading from StoreGate.
AthAlgTool
Definition: AthAlgTool.h:26
python.IoTestsLib.w
def w
Definition: IoTestsLib.py:198
InDet::TRT_TrackSegmentsMaker_ECcosmics::EventData::m_segments
std::list< Trk::TrackSegment * > m_segments
List of found segments.
Definition: TRT_TrackSegmentsMaker_ECcosmics.h:142
FitQuality.h
InDet::TRT_TrackSegmentsMaker_ECcosmics::EventData::m_a_phi
double m_a_phi[1000]
Definition: TRT_TrackSegmentsMaker_ECcosmics.h:146
Trk::Surface
Definition: Tracking/TrkDetDescr/TrkSurfaces/TrkSurfaces/Surface.h:79
InDet::TRT_TrackSegmentsMaker_ECcosmics::m_scaleTube
DoubleProperty m_scaleTube
Definition: TRT_TrackSegmentsMaker_ECcosmics.h:185
InDet::ITRT_TrackSegmentsMaker::IEventData
Definition: ITRT_TrackSegmentsMaker.h:53
InDet::TRT_TrackSegmentsMaker_ECcosmics::dump
virtual MsgStream & dump(MsgStream &out) const override
Definition: TRT_TrackSegmentsMaker_ECcosmics.cxx:1528
python.compressB64.c
def c
Definition: compressB64.py:93
InDet::TRT_TrackSegmentsMaker_ECcosmics::m_trtname
SG::ReadHandleKey< InDet::TRT_DriftCircleContainer > m_trtname
TRTs container.
Definition: TRT_TrackSegmentsMaker_ECcosmics.h:170
Trk::Segment::TRT_SegmentMaker
@ TRT_SegmentMaker
Definition: Tracking/TrkEvent/TrkSegment/TrkSegment/Segment.h:73
python.Dumpers.FitQuality
FitQuality
Definition: Dumpers.py:62
match
bool match(std::string s1, std::string s2)
match the individual directories of two strings
Definition: hcg.cxx:356
Trk::StraightLineSurface
Definition: StraightLineSurface.h:51
python.SystemOfUnits.ns
float ns
Definition: SystemOfUnits.py:146
InDet::TRT_TrackSegmentsMaker_ECcosmics::s_fitMutex
static std::mutex s_fitMutex
Definition: TRT_TrackSegmentsMaker_ECcosmics.h:202
InDet::TRT_TrackSegmentsMaker_ECcosmics::retrieveHits
void retrieveHits(TRT_TrackSegmentsMaker_ECcosmics::EventData &event_data) const
sort hits into good/noise lists
Definition: TRT_TrackSegmentsMaker_ECcosmics.cxx:1548
Identifier
Definition: IdentifierFieldParser.cxx:14