CMS 3D CMS Logo

ProxyPixelTopology.h
Go to the documentation of this file.
1 #ifndef Geometry_CommonTopologies_ProxyPixelTopology_H
2 #define Geometry_CommonTopologies_ProxyPixelTopology_H
3 
15 //
21 
25 
26 class Plane;
27 
28 class ProxyPixelTopology final : public PixelTopology {
29 public:
31 
32  LocalPoint localPosition(const MeasurementPoint &) const override;
34  LocalPoint localPosition(const MeasurementPoint &mp, const Topology::LocalTrackPred &trkPred) const override;
35 
36  LocalError localError(const MeasurementPoint &, const MeasurementError &) const override;
39  const MeasurementError &me,
40  const Topology::LocalTrackPred &trkPred) const override;
41 
42  MeasurementPoint measurementPosition(const LocalPoint &) const override;
44 
45  MeasurementError measurementError(const LocalPoint &lp, const LocalError &le) const override;
47  const LocalError &le,
48  const Topology::LocalTrackAngles &dir) const override;
49 
50  int channel(const LocalPoint &) const override;
51  int channel(const LocalPoint &lp, const Topology::LocalTrackAngles &dir) const override;
52 
53  std::pair<float, float> pixel(const LocalPoint &p) const override;
55  std::pair<float, float> pixel(const LocalPoint &p, const Topology::LocalTrackAngles &ltp) const override;
56 
57  std::pair<float, float> pitch() const override { return specificTopology().pitch(); }
58  int nrows() const override { return specificTopology().nrows(); }
59  int ncolumns() const override { return specificTopology().ncolumns(); }
60  int rocsY() const override { return specificTopology().rocsY(); }
61  int rocsX() const override { return specificTopology().rocsX(); }
62  int rowsperroc() const override { return specificTopology().rowsperroc(); }
63  int colsperroc() const override { return specificTopology().colsperroc(); }
64  float localX(const float mpX) const override;
65  float localX(const float mpX, const Topology::LocalTrackPred &trkPred) const override;
66  float localY(const float mpY) const override;
67  float localY(const float mpY, const Topology::LocalTrackPred &trkPred) const override;
68 
69  bool isItBigPixelInX(const int ixbin) const override { return specificTopology().isItBigPixelInX(ixbin); }
70  bool isItBigPixelInY(const int iybin) const override { return specificTopology().isItBigPixelInY(iybin); }
71  bool containsBigPixelInX(int ixmin, int ixmax) const override {
72  return specificTopology().containsBigPixelInX(ixmin, ixmax);
73  }
74  bool containsBigPixelInY(int iymin, int iymax) const override {
75  return specificTopology().containsBigPixelInY(iymin, iymax);
76  }
77 
78  bool isItEdgePixelInX(int ixbin) const override { return specificTopology().isItEdgePixelInX(ixbin); }
79  bool isItEdgePixelInY(int iybin) const override { return specificTopology().isItEdgePixelInY(iybin); }
80  bool isItEdgePixel(int ixbin, int iybin) const override { return specificTopology().isItEdgePixel(ixbin, iybin); }
81 
82  virtual const GeomDetType &type() const { return *theType; }
83 
84  virtual PixelGeomDetType const &specificType() const { return *theType; }
85 
86  const SurfaceDeformation *surfaceDeformation() const { return theSurfaceDeformation.operator->(); }
87  virtual void setSurfaceDeformation(const SurfaceDeformation *deformation);
88 
89  virtual const PixelTopology &specificTopology() const { return specificType().specificTopology(); }
90 
91 private:
95  const Topology::LocalTrackAngles &dir) const;
99 
102  std::unique_ptr<const SurfaceDeformation> theSurfaceDeformation;
103 };
104 
105 #endif
virtual void setSurfaceDeformation(const SurfaceDeformation *deformation)
LocalPoint localPosition(const MeasurementPoint &) const override
std::pair< float, float > pitch() const override
PixelGeomDetType const * theType
int nrows() const override
virtual int ncolumns() const =0
LocalError localError(const MeasurementPoint &, const MeasurementError &) const override
SurfaceDeformation::Local2DVector positionCorrection(const LocalPoint &pos, const Topology::LocalTrackAngles &dir) const
virtual int rowsperroc() const =0
bool isItEdgePixelInY(int iybin) const override
virtual int nrows() const =0
int channel(const LocalPoint &) const override
bool containsBigPixelInX(int ixmin, int ixmax) const override
virtual int rocsX() const =0
Definition: Plane.h:16
ProxyPixelTopology(PixelGeomDetType const *type, Plane *bp)
MeasurementError measurementError(const LocalPoint &lp, const LocalError &le) const override
virtual bool isItEdgePixelInX(int ixbin) const =0
virtual bool containsBigPixelInY(int iymin, int iymax) const =0
virtual bool isItBigPixelInX(int ixbin) const =0
virtual int colsperroc() const =0
float localY(const float mpY) const override
virtual bool isItBigPixelInY(int iybin) const =0
virtual bool containsBigPixelInX(int ixmin, int ixmax) const =0
int rowsperroc() const override
bool containsBigPixelInY(int iymin, int iymax) const override
bool isItEdgePixel(int ixbin, int iybin) const override
virtual int rocsY() const =0
int rocsY() const override
bool isItEdgePixelInX(int ixbin) const override
int ncolumns() const override
virtual const GeomDetType & type() const
virtual const PixelTopology & specificTopology() const
std::pair< float, float > pixel(const LocalPoint &p) const override
bool isItBigPixelInX(const int ixbin) const override
int colsperroc() const override
float localX(const float mpX) const override
std::unique_ptr< const SurfaceDeformation > theSurfaceDeformation
virtual bool isItEdgePixelInY(int iybin) const =0
virtual PixelGeomDetType const & specificType() const
bool isItBigPixelInY(const int iybin) const override
virtual std::pair< float, float > pitch() const =0
int rocsX() const override
const SurfaceDeformation * surfaceDeformation() const
virtual const TopologyType & specificTopology() const
MeasurementPoint measurementPosition(const LocalPoint &) const override
virtual bool isItEdgePixel(int ixbin, int iybin) const =0