![]() |
Belle II Software release-09-00-03
|
KFitBase is a base class for kinematical fitters. More...
#include <KFitBase.h>


Public Member Functions | |
| KFitBase (void) | |
| Construct an object with no argument. | |
| virtual | ~KFitBase (void) |
| Destruct the object. | |
| enum KFitError::ECode | addTrack (const KFitTrack &kp) |
| Add a track to the fitter object. | |
| enum KFitError::ECode | addTrack (const CLHEP::HepLorentzVector &p, const HepPoint3D &x, const CLHEP::HepSymMatrix &e, const double q) |
| Add a track to the fitter object with specifying its momentum, position, error matrix, and charge. | |
| enum KFitError::ECode | addParticle (const Particle *particle) |
| Add a particle to the fitter. | |
| virtual enum KFitError::ECode | setCorrelation (const CLHEP::HepMatrix &c) |
| Set a correlation matrix. | |
| virtual enum KFitError::ECode | setZeroCorrelation (void) |
| Indicate no correlation between tracks. | |
| enum KFitError::ECode | setMagneticField (const double mf) |
| Change a magnetic field from the default value KFitConst::kDefaultMagneticField. | |
| enum KFitError::ECode | getErrorCode (void) const |
| Get a code of the last error. | |
| int | getTrackCount (void) const |
| Get the number of added tracks. | |
| virtual int | getNDF (void) const |
| Get an NDF of the fit. | |
| virtual double | getCHIsq (void) const |
| Get a chi-square of the fit. | |
| double | getMagneticField (void) const |
| Get a magnetic field. | |
| virtual double | getTrackCHIsq (const int id) const |
| Get a chi-square of the track. | |
| const CLHEP::HepLorentzVector | getTrackMomentum (const int id) const |
| Get a Lorentz vector of the track. | |
| const HepPoint3D | getTrackPosition (const int id) const |
| Get a position of the track. | |
| const CLHEP::HepSymMatrix | getTrackError (const int id) const |
| Get an error matrix of the track. | |
| const KFitTrack | getTrack (const int id) const |
| Get a specified track object. | |
| virtual const CLHEP::HepMatrix | getCorrelation (const int id1, const int id2, const int flag=KFitConst::kAfterFit) const |
| Get a correlation matrix between two tracks. | |
| bool | isFitted (void) const |
| Return false if fit is not performed yet or performed fit is failed; otherwise true. | |
Protected Member Functions | |
| const CLHEP::HepSymMatrix | makeError1 (const CLHEP::HepLorentzVector &p, const CLHEP::HepMatrix &e) const |
| Rebuild an error matrix from a Lorentz vector and an error matrix. | |
| const CLHEP::HepMatrix | makeError1 (const CLHEP::HepLorentzVector &p1, const CLHEP::HepLorentzVector &p2, const CLHEP::HepMatrix &e) const |
| Rebuild an error matrix from a pair of Lorentz vectors and an error matrix. | |
| const CLHEP::HepMatrix | makeError2 (const CLHEP::HepLorentzVector &p, const CLHEP::HepMatrix &e) const |
| Rebuild an error matrix from a Lorentz vector and an error matrix. | |
| const CLHEP::HepSymMatrix | makeError3 (const CLHEP::HepLorentzVector &p, const CLHEP::HepMatrix &e, const bool is_fix_mass) const |
| Rebuild an error matrix from a Lorentz vector and an error matrix. | |
| const CLHEP::HepMatrix | makeError3 (const CLHEP::HepLorentzVector &p1, const CLHEP::HepLorentzVector &p2, const CLHEP::HepMatrix &e, const bool is_fix_mass1, const bool is_fix_mass2) const |
| Rebuild an error matrix from a pair of Lorentz vectors and an error matrix. | |
| const CLHEP::HepMatrix | makeError4 (const CLHEP::HepLorentzVector &p, const CLHEP::HepMatrix &e) const |
| Rebuild an error matrix from a Lorentz vector and an error matrix. | |
| virtual enum KFitError::ECode | prepareInputMatrix (void)=0 |
| Build grand matrices for minimum search from input-track properties. | |
| virtual enum KFitError::ECode | prepareInputSubMatrix (void)=0 |
| Build sub-matrices for minimum search from input-track properties. | |
| virtual enum KFitError::ECode | prepareCorrelation (void) |
| Build a grand correlation matrix from input-track properties. | |
| virtual enum KFitError::ECode | prepareOutputMatrix (void)=0 |
| Build an output error matrix. | |
| virtual enum KFitError::ECode | makeCoreMatrix (void)=0 |
| Build matrices using the kinematical constraint. | |
| virtual enum KFitError::ECode | calculateNDF (void)=0 |
| Calculate an NDF of the fit. | |
| enum KFitError::ECode | doFit1 (void) |
| Perform a fit (used in MassFitKFit::doFit()). | |
| enum KFitError::ECode | doFit2 (void) |
| Perform a fit (used in VertexFitKFit::doFit() and MassVertexFitKFit::doFit()). | |
| bool | isTrackIDInRange (const int id) const |
| Check if the id is in the range. | |
| bool | isNonZeroEnergy (const CLHEP::HepLorentzVector &p) const |
| Check if the energy is non-zero. | |
Protected Attributes | |
| enum KFitError::ECode | m_ErrorCode |
| Error code. | |
| bool | m_FlagFitted |
| Flag to indicate if the fit is performed and succeeded. | |
| std::vector< KFitTrack > | m_Tracks |
| Container of input tracks. | |
| std::vector< CLHEP::HepMatrix > | m_BeforeCorrelation |
| Container of input correlation matrices. | |
| CLHEP::HepSymMatrix | m_V_al_0 |
| See J.Tanaka Ph.D (2001) p137 for definition. | |
| CLHEP::HepMatrix | m_al_0 |
| See J.Tanaka Ph.D (2001) p136 for definition. | |
| CLHEP::HepMatrix | m_al_1 |
| See J.Tanaka Ph.D (2001) p136 for definition. | |
| CLHEP::HepMatrix | m_al_a |
| See J.Tanaka Ph.D (2001) p137 for definition. | |
| CLHEP::HepMatrix | m_property |
| Container of charges and masses. | |
| CLHEP::HepMatrix | m_D |
| See J.Tanaka Ph.D (2001) p137 for definition. | |
| CLHEP::HepMatrix | m_d |
| See J.Tanaka Ph.D (2001) p137 for definition. | |
| CLHEP::HepMatrix | m_V_D |
| See J.Tanaka Ph.D (2001) p138 for definition. | |
| CLHEP::HepMatrix | m_V_al_1 |
| See J.Tanaka Ph.D (2001) p138 for definition. | |
| CLHEP::HepMatrix | m_lam |
| See J.Tanaka Ph.D (2001) p137 for definition. | |
| CLHEP::HepMatrix | m_E |
| See J.Tanaka Ph.D (2001) p137 for definition. | |
| CLHEP::HepMatrix | m_V_E |
| See J.Tanaka Ph.D (2001) p138 for definition. | |
| CLHEP::HepMatrix | m_lam0 |
| See J.Tanaka Ph.D (2001) p138 for definition. | |
| CLHEP::HepMatrix | m_v |
| See J.Tanaka Ph.D (2001) p137 for definition. | |
| CLHEP::HepMatrix | m_v_a |
| See J.Tanaka Ph.D (2001) p137 for definition. | |
| CLHEP::HepMatrix | m_V_Dt |
| See J.Tanaka Ph.D (2001) p138 for definition. | |
| CLHEP::HepMatrix | m_Cov_v_al_1 |
| See J.Tanaka Ph.D (2001) p137 for definition. | |
| int | m_NDF |
| NDF of the fit. | |
| double | m_CHIsq |
| chi-square of the fit. | |
| int | m_TrackCount |
| Number of tracks. | |
| int | m_NecessaryTrackCount |
| Number needed tracks to perform fit. | |
| bool | m_FlagCorrelation |
| Flag whether a correlation among tracks exists. | |
| bool | m_FlagOverIteration |
| Flag whether the iteration count exceeds the limit. | |
| double | m_MagneticField |
| Magnetic field. | |
KFitBase is a base class for kinematical fitters.
Definition at line 37 of file KFitBase.h.
| KFitBase | ( | void | ) |
Construct an object with no argument.
Definition at line 20 of file KFitBase.cc.
| enum KFitError::ECode addParticle | ( | const Particle * | particle | ) |
Add a particle to the fitter.
The function gets track parameters from the Particle dataobject and calls addTrack().
| [in] | particle | Particle. |
Definition at line 59 of file KFitBase.cc.
| enum KFitError::ECode addTrack | ( | const CLHEP::HepLorentzVector & | p, |
| const HepPoint3D & | x, | ||
| const CLHEP::HepSymMatrix & | e, | ||
| const double | q | ||
| ) |
Add a track to the fitter object with specifying its momentum, position, error matrix, and charge.
This function internally calls addTrack(const KFitTrack &kp).
| p | Lorentz vector of the track |
| x | position of the track |
| e | (7x7) error matrix of the track |
| q | charge of the track |
Definition at line 47 of file KFitBase.cc.
| enum KFitError::ECode addTrack | ( | const KFitTrack & | kp | ) |
Add a track to the fitter object.
| kp | object of the track |
Definition at line 38 of file KFitBase.cc.
|
protectedpure virtual |
Calculate an NDF of the fit.
Implemented in FourCFitKFit, MassFitKFit, MassFourCFitKFit, MassPointingVertexFitKFit, MassVertexFitKFit, RecoilMassKFit, and VertexFitKFit.
|
protected |
Perform a fit (used in MassFitKFit::doFit()).
Definition at line 502 of file KFitBase.cc.
|
protected |
Perform a fit (used in VertexFitKFit::doFit() and MassVertexFitKFit::doFit()).
Definition at line 578 of file KFitBase.cc.
|
virtual |
Get a chi-square of the fit.
Reimplemented in FourCFitKFit, MassFitKFit, MassFourCFitKFit, MassPointingVertexFitKFit, MassVertexFitKFit, RecoilMassKFit, and VertexFitKFit.
Definition at line 121 of file KFitBase.cc.
|
virtual |
Get a correlation matrix between two tracks.
| id1 | first track id |
| id2 | second track id |
| flag | KFitConst::kBeforeFit or KFitConst::kAfterFit |
Reimplemented in FourCFitKFit, MassFitKFit, MassFourCFitKFit, MassPointingVertexFitKFit, MassVertexFitKFit, and RecoilMassKFit.
Definition at line 183 of file KFitBase.cc.
| enum KFitError::ECode getErrorCode | ( | void | ) | const |
Get a code of the last error.
Definition at line 101 of file KFitBase.cc.
| double getMagneticField | ( | void | ) | const |
|
virtual |
| const KFitTrack getTrack | ( | const int | id | ) | const |
Get a specified track object.
| id | track id |
Definition at line 175 of file KFitBase.cc.
|
virtual |
Get a chi-square of the track.
| id | track id |
Reimplemented in FourCFitKFit, MassFitKFit, MassFourCFitKFit, MassPointingVertexFitKFit, MassVertexFitKFit, RecoilMassKFit, and VertexFitKFit.
Definition at line 135 of file KFitBase.cc.
| int getTrackCount | ( | void | ) | const |
Get the number of added tracks.
Definition at line 107 of file KFitBase.cc.
| const HepSymMatrix getTrackError | ( | const int | id | ) | const |
Get an error matrix of the track.
| id | track id |
Definition at line 168 of file KFitBase.cc.
| const HepLorentzVector getTrackMomentum | ( | const int | id | ) | const |
Get a Lorentz vector of the track.
| id | track id |
Definition at line 154 of file KFitBase.cc.
| const HepPoint3D getTrackPosition | ( | const int | id | ) | const |
Get a position of the track.
| id | track id |
Definition at line 161 of file KFitBase.cc.
| bool isFitted | ( | void | ) | const |
Return false if fit is not performed yet or performed fit is failed; otherwise true.
Definition at line 728 of file KFitBase.cc.
|
protected |
Check if the energy is non-zero.
| p | Lorentz vector |
Definition at line 750 of file KFitBase.cc.
|
protected |
Check if the id is in the range.
| id | track id |
Definition at line 739 of file KFitBase.cc.
|
protectedpure virtual |
Build matrices using the kinematical constraint.
Implemented in FourCFitKFit, MassFitKFit, MassFourCFitKFit, MassPointingVertexFitKFit, MassVertexFitKFit, RecoilMassKFit, and VertexFitKFit.
|
protected |
Rebuild an error matrix from a Lorentz vector and an error matrix.
| p | Lorentz vector |
| e | (6x6) error matrix |
Definition at line 221 of file KFitBase.cc.
|
protected |
Rebuild an error matrix from a pair of Lorentz vectors and an error matrix.
| p1 | first Lorentz vector |
| p2 | second Lorentz vector |
| e | (6x6) error matrix |
Definition at line 255 of file KFitBase.cc.
|
protected |
Rebuild an error matrix from a Lorentz vector and an error matrix.
| p | Lorentz vector |
| e | (3x6) error matrix |
Definition at line 296 of file KFitBase.cc.
|
protected |
Rebuild an error matrix from a Lorentz vector and an error matrix.
| p | Lorentz vector |
| e | (7x7) error matrix |
| is_fix_mass | true to recalculate energy term from other parameters, false to do nothing |
Definition at line 320 of file KFitBase.cc.
|
protected |
Rebuild an error matrix from a pair of Lorentz vectors and an error matrix.
| p1 | first Lorentz vector |
| p2 | second Lorentz vector |
| e | (7x7) error matrix |
| is_fix_mass1 | true to recalculate energy term from other parameters, false to do nothing |
| is_fix_mass2 | true to recalculate energy term from other parameters, false to do nothing |
Definition at line 361 of file KFitBase.cc.
|
protected |
Rebuild an error matrix from a Lorentz vector and an error matrix.
| p | Lorentz vector |
| e | (3x7) error matrix |
Definition at line 439 of file KFitBase.cc.
|
protectedvirtual |
Build a grand correlation matrix from input-track properties.
Reimplemented in FourCFitKFit, MassFitKFit, MassFourCFitKFit, MassPointingVertexFitKFit, MassVertexFitKFit, and RecoilMassKFit.
Definition at line 459 of file KFitBase.cc.
|
protectedpure virtual |
Build grand matrices for minimum search from input-track properties.
Implemented in FourCFitKFit, MassFitKFit, MassFourCFitKFit, MassPointingVertexFitKFit, MassVertexFitKFit, RecoilMassKFit, and VertexFitKFit.
|
protectedpure virtual |
Build sub-matrices for minimum search from input-track properties.
Implemented in FourCFitKFit, MassFitKFit, MassFourCFitKFit, MassPointingVertexFitKFit, MassVertexFitKFit, RecoilMassKFit, and VertexFitKFit.
|
protectedpure virtual |
Build an output error matrix.
Implemented in FourCFitKFit, MassFitKFit, MassFourCFitKFit, MassPointingVertexFitKFit, MassVertexFitKFit, RecoilMassKFit, and VertexFitKFit.
|
virtual |
Set a correlation matrix.
Not intended for end user's use.
| c | (7x7) correlation matrix |
Reimplemented in FourCFitKFit, MassFitKFit, MassFourCFitKFit, MassPointingVertexFitKFit, MassVertexFitKFit, and RecoilMassKFit.
Definition at line 70 of file KFitBase.cc.
| enum KFitError::ECode setMagneticField | ( | const double | mf | ) |
Change a magnetic field from the default value KFitConst::kDefaultMagneticField.
| mf | magnetic field to set |
Definition at line 93 of file KFitBase.cc.
|
virtual |
Indicate no correlation between tracks.
Not intended for end user's use.
Reimplemented in FourCFitKFit, MassFitKFit, MassFourCFitKFit, MassPointingVertexFitKFit, MassVertexFitKFit, and RecoilMassKFit.
Definition at line 85 of file KFitBase.cc.
|
protected |
See J.Tanaka Ph.D (2001) p136 for definition.
Definition at line 257 of file KFitBase.h.
|
protected |
See J.Tanaka Ph.D (2001) p136 for definition.
Definition at line 259 of file KFitBase.h.
|
protected |
See J.Tanaka Ph.D (2001) p137 for definition.
Definition at line 261 of file KFitBase.h.
|
protected |
Container of input correlation matrices.
Definition at line 251 of file KFitBase.h.
|
protected |
chi-square of the fit.
Definition at line 297 of file KFitBase.h.
|
protected |
See J.Tanaka Ph.D (2001) p137 for definition.
Definition at line 291 of file KFitBase.h.
|
protected |
See J.Tanaka Ph.D (2001) p137 for definition.
Definition at line 266 of file KFitBase.h.
|
protected |
See J.Tanaka Ph.D (2001) p137 for definition.
Definition at line 268 of file KFitBase.h.
|
protected |
See J.Tanaka Ph.D (2001) p137 for definition.
Definition at line 279 of file KFitBase.h.
|
protected |
Error code.
Definition at line 243 of file KFitBase.h.
|
protected |
Flag whether a correlation among tracks exists.
Definition at line 306 of file KFitBase.h.
|
protected |
Flag to indicate if the fit is performed and succeeded.
Definition at line 245 of file KFitBase.h.
|
protected |
Flag whether the iteration count exceeds the limit.
Definition at line 308 of file KFitBase.h.
|
protected |
See J.Tanaka Ph.D (2001) p137 for definition.
Definition at line 276 of file KFitBase.h.
|
protected |
See J.Tanaka Ph.D (2001) p138 for definition.
Definition at line 283 of file KFitBase.h.
|
protected |
Magnetic field.
Definition at line 311 of file KFitBase.h.
|
protected |
NDF of the fit.
Definition at line 295 of file KFitBase.h.
|
protected |
Number needed tracks to perform fit.
Definition at line 303 of file KFitBase.h.
|
protected |
Container of charges and masses.
Definition at line 263 of file KFitBase.h.
|
protected |
Number of tracks.
Definition at line 301 of file KFitBase.h.
|
protected |
Container of input tracks.
Definition at line 249 of file KFitBase.h.
|
protected |
See J.Tanaka Ph.D (2001) p137 for definition.
Definition at line 285 of file KFitBase.h.
|
protected |
See J.Tanaka Ph.D (2001) p137 for definition.
Definition at line 287 of file KFitBase.h.
|
protected |
See J.Tanaka Ph.D (2001) p137 for definition.
Definition at line 255 of file KFitBase.h.
|
protected |
See J.Tanaka Ph.D (2001) p138 for definition.
Definition at line 274 of file KFitBase.h.
|
protected |
See J.Tanaka Ph.D (2001) p138 for definition.
Definition at line 271 of file KFitBase.h.
|
protected |
See J.Tanaka Ph.D (2001) p138 for definition.
Definition at line 289 of file KFitBase.h.
|
protected |
See J.Tanaka Ph.D (2001) p138 for definition.
Definition at line 281 of file KFitBase.h.