SND@LHC Software
Loading...
Searching...
No Matches
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
33namespace genfit {
34
35class KalmanFitterInfo;
36class MeasuredStateOnPlane;
37class TrackPoint;
38
43
44 private:
45
46 // These private functions are needed, otherwise strange things happen, no idea why!
49
50 public:
51
52 KalmanFitter(unsigned int maxIterations = 4, double deltaPval = 1e-3, double blowUpFactor = 1e3, bool squareRootFormalism = false)
53 : AbsKalmanFitter(maxIterations, deltaPval, blowUpFactor), currentState_(NULL),
54 squareRootFormalism_(squareRootFormalism)
55 {}
56
58
60 void processTrackWithRep(Track* tr, const AbsTrackRep* rep, bool resortHits = false);
61
64 void processTrackPartially(Track* tr, const AbsTrackRep* rep, int startId = 0, int endId = -1);
65
66 void useSquareRootFormalism(bool squareRootFormalism = true) {squareRootFormalism_ = squareRootFormalism;}
67
68 private:
69 bool fitTrack(Track* tr, const AbsTrackRep* rep, double& chi2, double& ndf, int startId, int endId, int& nFailedHits);
71 const AbsTrackRep* rep, double& chi2, double& ndf, int direction);
72
73#ifndef __CINT__
74 boost::scoped_ptr<MeasuredStateOnPlane> currentState_;
75#else
77#endif
78
80
81 public:
82 ClassDef(KalmanFitter,1)
83
84};
85
86} /* End of namespace genfit */
89#endif //genfit_KalmanFitter_h
Abstract base class for Kalman fitter and derived fitting algorithms.
Abstract base class for a track representation.
Definition AbsTrackRep.h:66
Simple Kalman filter implementation.
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.
boost::scoped_ptr< MeasuredStateOnPlane > currentState_
void useSquareRootFormalism(bool squareRootFormalism=true)
KalmanFitter(const KalmanFitter &)
KalmanFitter & operator=(KalmanFitter const &)
bool fitTrack(Track *tr, const AbsTrackRep *rep, double &chi2, double &ndf, int startId, int endId, int &nFailedHits)
KalmanFitter(unsigned int maxIterations=4, double deltaPval=1e-3, double blowUpFactor=1e3, bool squareRootFormalism=false)
void processTrackPoint(TrackPoint *tp, const AbsTrackRep *rep, double &chi2, double &ndf, int direction)
StateOnPlane with additional covariance matrix.
Object containing AbsMeasurement and AbsFitterInfo objects.
Definition TrackPoint.h:50
Collection of TrackPoint objects, AbsTrackRep objects and FitStatus objects.
Definition Track.h:71
Matrix inversion tools.
Definition AbsBField.h:29