PandaRoot
KalmanFitter.h
Go to the documentation of this file.
1 /* Copyright 2013, Ludwig-Maximilians Universität München,
2  Authors: Tobias Schlüter & 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_KalmanFitter_h
24 #define genfit_KalmanFitter_h
25 
26 #include "AbsKalmanFitter.h"
27 
28 #ifndef __CINT__
29 #include <boost/scoped_ptr.hpp>
30 #endif
31 
32 namespace genfit {
33 
34 class KalmanFitterInfo;
35 class MeasuredStateOnPlane;
36 class TrackPoint;
37 
41 class KalmanFitter : public AbsKalmanFitter {
42 
43  private:
44  // These private functions are needed, otherwise strange things happen, no idea why!
45  KalmanFitter(const KalmanFitter &);
46  KalmanFitter &operator=(KalmanFitter const &);
47 
48  public:
49  KalmanFitter(unsigned int maxIterations = 4, double deltaPval = 1e-3, double blowUpFactor = 1e3, bool squareRootFormalism = false)
50  : AbsKalmanFitter(maxIterations, deltaPval, blowUpFactor), currentState_(nullptr), squareRootFormalism_(squareRootFormalism)
51  {
52  }
53 
55 
57  void processTrackWithRep(Track *tr, const AbsTrackRep *rep, bool resortHits = false);
58 
61  void processTrackPartially(Track *tr, const AbsTrackRep *rep, int startId = 0, int endId = -1);
62 
63  void useSquareRootFormalism(bool squareRootFormalism = true) { squareRootFormalism_ = squareRootFormalism; }
64 
65  private:
66  bool fitTrack(Track *tr, const AbsTrackRep *rep, double &chi2, double &ndf, int startId, int endId, int &nFailedHits);
67  void processTrackPoint(TrackPoint *tp, const AbsTrackRep *rep, double &chi2, double &ndf, int direction);
68 
69 #ifndef __CINT__
70  boost::scoped_ptr<MeasuredStateOnPlane> currentState_;
71 #else
72  MeasuredStateOnPlane *currentState_;
73 #endif
74 
75  bool squareRootFormalism_;
76 
77  public:
78  ClassDef(KalmanFitter, 1)
79 };
80 
81 } /* End of namespace genfit */
84 #endif // genfit_KalmanFitter_h
void useSquareRootFormalism(bool squareRootFormalism=true)
Definition: KalmanFitter.h:63
Simple Kalman filter implementation.
Definition: KalmanFitter.h:41
Collection of TrackPoint objects, AbsTrackRep objects and FitStatus objects.
Definition: Track.h:67
Abstract base class for a track representation.
Definition: AbsTrackRep.h:62
StateOnPlane with additional covariance matrix.
Abstract base class for Kalman fitter and derived fitting algorithms.
Object containing AbsMeasurement and AbsFitterInfo objects.
Definition: TrackPoint.h:49
void processTrackPartially(Track *tr, const AbsTrackRep *rep, int startId=0, int endId=-1)
void processTrackWithRep(Track *tr, const AbsTrackRep *rep, bool resortHits=false)
Hit resorting currently NOT supported.
KalmanFitter(unsigned int maxIterations=4, double deltaPval=1e-3, double blowUpFactor=1e3, bool squareRootFormalism=false)
Definition: KalmanFitter.h:49
Matrix inversion tools.
Definition: AbsBField.h:28