Belle II Software  release-08-02-04
WireMeasurement.h
1 /* Copyright 2008-2010, Technische Universitaet Muenchen,
2  Authors: Christian Hoeppner & Sebastian Neubert & Johannes Rauch
3 
4  This file is part of GENFIT.
5 
6  GENFIT is free software: you can redistribute it and/or modify
7  it under the terms of the GNU Lesser General Public License as published
8  by the Free Software Foundation, either version 3 of the License, or
9  (at your option) any later version.
10 
11  GENFIT is distributed in the hope that it will be useful,
12  but WITHOUT ANY WARRANTY; without even the implied warranty of
13  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14  GNU Lesser General Public License for more details.
15 
16  You should have received a copy of the GNU Lesser General Public License
17  along with GENFIT. If not, see <http://www.gnu.org/licenses/>.
18 */
23 #ifndef genfit_WireMeasurement_h
24 #define genfit_WireMeasurement_h
25 
26 #include "AbsMeasurement.h"
27 #include "AbsHMatrix.h"
28 #include "MeasurementOnPlane.h"
29 
30 
31 namespace genfit {
32 
53 
54  public:
55  WireMeasurement(int nDim = 7);
56  WireMeasurement(const TVectorD& rawHitCoords, const TMatrixDSym& rawHitCov, int detId, int hitId, TrackPoint* trackPoint);
57 
58  virtual ~WireMeasurement() {;}
59 
60  virtual AbsMeasurement* clone() const override {return new WireMeasurement(*this);}
61 
62  virtual SharedPlanePtr constructPlane(const StateOnPlane& state) const override;
63 
74  virtual std::vector<MeasurementOnPlane*> constructMeasurementsOnPlane(const StateOnPlane& state) const override;
75 
76  virtual const AbsHMatrix* constructHMatrix(const AbsTrackRep*) const override;
77 
81  void setMaxDistance(double d){maxDistance_ = d;}
88  void setLeftRightResolution(int lr);
89 
90  virtual bool isLeftRightMeasurement() const override {return true;}
91  virtual int getLeftRightResolution() const override {return leftRight_;}
92 
93  double getMaxDistance(){return maxDistance_;}
94 
95  protected:
96 
97  double maxDistance_;
98  signed char leftRight_;
99 
100  public:
101 
102  ClassDefOverride(WireMeasurement, 2)
103 
104 };
105 
106 } /* End of namespace genfit */
109 #endif // genfit_WireMeasurement_h
HMatrix for projecting from AbsTrackRep parameters to measured parameters in a DetPlane.
Definition: AbsHMatrix.h:37
Contains the measurement and covariance in raw detector coordinates.
Abstract base class for a track representation.
Definition: AbsTrackRep.h:66
A state with arbitrary dimension defined in a DetPlane.
Definition: StateOnPlane.h:47
Object containing AbsMeasurement and AbsFitterInfo objects.
Definition: TrackPoint.h:46
Class for measurements in wire detectors (Straw tubes and drift chambers) which do not measure the co...
virtual bool isLeftRightMeasurement() const override
If the AbsMeasurement is a wire hit, the left/right resolution will be used.
virtual SharedPlanePtr constructPlane(const StateOnPlane &state) const override
Construct (virtual) detector plane (use state's AbsTrackRep).
virtual AbsMeasurement * clone() const override
Deep copy ctor for polymorphic class.
void setMaxDistance(double d)
Set maximum drift distance.
void setLeftRightResolution(int lr)
select how to resolve the left/right ambiguity: -1: negative (left) side on vector (track direction) ...
virtual std::vector< MeasurementOnPlane * > constructMeasurementsOnPlane(const StateOnPlane &state) const override
Hits with a small drift distance get a higher weight, whereas hits with big drift distances become we...
virtual const AbsHMatrix * constructHMatrix(const AbsTrackRep *) const override
Returns a new AbsHMatrix object.
Defines for I/O streams used for error and debug printing.
std::shared_ptr< genfit::DetPlane > SharedPlanePtr
Shared Pointer to a DetPlane.