CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
ProjectedRecHit2D.cc
Go to the documentation of this file.
5 
6 
7 ProjectedRecHit2D::ProjectedRecHit2D( const LocalPoint& pos, const LocalError& err,
8  const GeomDet* det, const GeomDet* originalDet,
9  const TransientTrackingRecHit& originalTransientHit) :
10  GenericTransientTrackingRecHit( det, new ProjectedSiStripRecHit2D( pos, err, det->geographicalId(),
11  static_cast<const SiStripRecHit2D*>(originalTransientHit.hit()) ) )
12 {
13  const TSiStripRecHit2DLocalPos* specificOriginalTransientHit = static_cast<const TSiStripRecHit2DLocalPos*>(&originalTransientHit);
14  theCPE = specificOriginalTransientHit->cpe();
15  theOriginalDet = originalDet;
16 }
17 
18 ProjectedRecHit2D::RecHitPointer
20 {
21  if (theCPE != 0) {
23  if(!originalHit().cluster().isNull()){
24  const SiStripCluster& clust = *(originalHit().cluster());
25 
26  const GeomDetUnit * gdu = reinterpret_cast<const GeomDetUnit *>(theOriginalDet);
27  //if (!gdu) std::cout<<"no luck dude"<<std::endl;
29  theCPE->localParameters( clust, *gdu, ts);
30 
31  RecHitPointer updatedOriginalHit =
32  TSiStripRecHit2DLocalPos::build( lv.first, lv.second, theOriginalDet,
33  originalHit().cluster(), theCPE);
34 
35  RecHitPointer hit = proj.project( *updatedOriginalHit, *det(), ts);
36 
37  return hit;
38  }else{
39  const SiStripCluster& clust = *(originalHit().cluster_regional());
40 
41  const GeomDetUnit * gdu = reinterpret_cast<const GeomDetUnit *>(theOriginalDet);
43  theCPE->localParameters( clust, *gdu, ts);
44 
45  RecHitPointer updatedOriginalHit =
46  TSiStripRecHit2DLocalPos::build( lv.first, lv.second, theOriginalDet,
47  originalHit().cluster_regional(), theCPE);
48 
49  RecHitPointer hit = proj.project( *updatedOriginalHit, *det(), ts);
50 
51  return hit;
52 
53  }
54  }
56  else return clone();
57 }
58 
60 ProjectedRecHit2D::transientHits () const {
62  result.push_back(TSiStripRecHit2DLocalPos::build( theOriginalDet,&originalHit(),theCPE));
63 
64  return result;
65 }
66 
67 ProjectedRecHit2D::ProjectedRecHit2D( const GeomDet * geom, const GeomDet* originaldet,
68  const ProjectedSiStripRecHit2D* rh,
70  bool computeCoarseLocalPosition) :
71  GenericTransientTrackingRecHit( geom, *rh), theCPE(cpe), theOriginalDet(originaldet) {
72  if (computeCoarseLocalPosition){
73  if (theCPE != 0) {
75  if(!originalHit().cluster().isNull()){
76  const SiStripCluster& clust = *(originalHit().cluster());
77 
79  theCPE->localParameters( clust, *detUnit());
80 
81  RecHitPointer updatedOriginalHit =
82  TSiStripRecHit2DLocalPos::build( lv.first, lv.second, theOriginalDet,
83  originalHit().cluster(), theCPE);
84 
85  RecHitPointer hit = proj.project( *updatedOriginalHit, *det());
86  trackingRecHit_ = hit->hit()->clone();
87  }else{
88  const SiStripCluster& clust = *(originalHit().cluster_regional());
89 
91  theCPE->localParameters( clust, *detUnit());
92 
93  RecHitPointer updatedOriginalHit =
94  TSiStripRecHit2DLocalPos::build( lv.first, lv.second, theOriginalDet,
95  originalHit().cluster_regional(), theCPE);
96 
97  RecHitPointer hit = proj.project( *updatedOriginalHit, *det());
98  trackingRecHit_ = hit->hit()->clone();
99  }
100  }
101  }
102 }
std::pair< LocalPoint, LocalError > LocalValues
RecHitPointer project(const TransientTrackingRecHit &hit, const GeomDet &det, const TrajectoryStateOnSurface &ts) const
tuple result
Definition: query.py:137
std::vector< ConstRecHitPointer > ConstRecHitContainer
string const
Definition: compareJSON.py:14
TEveGeoShape * clone(const TEveElement *element, TEveElement *parent)
Definition: eve_macros.cc:135
TransientTrackingRecHit::ConstRecHitContainer ConstRecHitContainer