// DKinFit class header file. -*- C++ -*- /** @file DKinFit/DKinFit.h * @brief DKinFit class defintion file. */ #ifndef _DKinFit_H #define _DKinFit_H // System Headers: #include #include #include #include // ROOT Headers: #include "TMatrixD.h" #include "TMath.h" #include "TLorentzVector.h" #include "TVector3.h" // Local Headers #include "DKinematicData.h" using namespace std; //_____________________________________________________________________________ class DKinFit { private: // Data Members (private): int _verbose; ///< Level of verbosity /* kinematic fitting statistical quantities */ std::vector _pulls; ///< Pull quantities of last fit double _chi2; ///< \f$ \chi^2 \f$ of last fit int _ndf; ///< Number of degrees-of-freedom of last fit /* kinematic quantities */ std::vector _kDataInitial_in; ///< Initial particle 4-momenta (in) std::vector _kDataFinal_in; ///< Final particle 4-momenta (in) std::vector _kDataInitial_out; ///< Initial particle 4-momenta (out) std::vector _kDataFinal_out; ///< Final particle 4-momenta (out) /* covariance matrix info */ TMatrixD _cov; ///< Covariance matrix double _sigma_missing[3]; ///< Fit errors on missing quantities /* missing particle info */ double _missingMass; ///< Mass of the missing particle bool _missingParticle; ///< Is there a missing particle? /* extra mass constraint info */ int _extraC; ///< How many extra mass constraints are there? double _invariantMass; ///< Invariant mass used in extra mass constraint std::vector _extraC_meas; ///< Which measured particles in constraint? std::vector _constraintMasses; ///< Masses for the extra constraint equations std::vector< std::vector > _constraintParticles; ///< Particles in the extra constraint equations ///< -1 is the missing mass std::vector _extraC_miss; ///< Is missing particle used in extra mass constraint? // Functions (private): // main kinematic fit function void _MainFitter(); // get ready for a new fit void _ResetForNewFit(); // copy the DKinFit data members void _Copy(const DKinFit &__kfit); // sets output quantities for a bad fit void _SetToBadFit(); // set the missing particle errors void _SetMissingParticleErrors(const TMatrixD &__missingCov, const TMatrixD &__x); public: // Create/Copy/Destroy: DKinFit(); DKinFit(const DKinFit &__kfit){ /// Copy Constructor this->_Copy(__kfit); } virtual ~DKinFit(){ /// Destructor _pulls.clear(); _kDataInitial_in.clear(); _kDataFinal_in.clear(); _kDataInitial_out.clear(); _kDataFinal_out.clear(); _extraC_meas.clear(); } DKinFit& operator=(const DKinFit &__kfit){ /// Assignment operator this->_Copy(__kfit); return *this; } // Setters: inline void SetCovMatrix(const TMatrixD &__covMat){ /// Set the covariance matrix. _cov.ResizeTo(__covMat); _cov = __covMat; } /// Set the input 4-momenta. inline void SetVerbose(int __verbose){_verbose = __verbose;} /// Set the initial tracks inline void SetInitial(std::vector &__kd) { _kDataInitial_in = __kd; } /// Set the final tracks inline void SetFinal(std::vector &__kd) { _kDataFinal_in = __kd; } /// Get the momenta BEFORE the kinematic fit inline std::vector GetInitial_in() { return _kDataInitial_in;} inline std::vector GetFinal_in() { return _kDataFinal_in;} /// Get the momenta AFTER the kinematic fit inline std::vector GetInitial_out() { return _kDataInitial_out;} inline std::vector GetFinal_out() { return _kDataFinal_out;} // Getters: /// Return \f$ \chi^2 \f$ of the last fit. inline double Chi2() const { return _chi2; } /// Return the number of degrees of freedom of the last fit inline int Ndf() const { return _ndf; } /// Returns the @a n pull quantity /** Pulls are stored as * \f$ (E_{\gamma},p_1,\lambda_1,\phi_1,...,p_n,\lambda_n,\phi_n) \f$ */ inline double GetPull(int __n) const { return _pulls[__n]; } /// Returns the @a n missing particle error (p,lambda,phi) inline double GetMissingError(int __n) const { return _sigma_missing[__n]; } /// Returns the covariance matrix inline const TMatrixD& GetCovMat() const { return _cov; } // Functions: /// Returns the confidence level of the last fit double Prob() const { return TMath::Prob(_chi2,_ndf); } // converts names to masses for the missing particle static double NameToMass(const string &__name); /// Set whether or not there's a missing particle void SetMissingParticle(const double __missingMass); /// Set each extra mass constraint void SetMassConstraint(const double __constraintMass, const vector constrainedParticles); // main kinematic fit function void Fit(); void FitTwoGammas(const float __missingMass, const float errmatrixweight); // Utility function DLorentzVector MissingMomentum(vector initial, vector final); }; //_____________________________________________________________________________ #endif /* _DKinFit_H */