File indexing completed on 2025-08-05 08:18:21
0001
0002
0003
0004
0005
0006
0007
0008
0009
0010
0011
0012
0013
0014
0015
0016
0017
0018
0019
0020
0021
0022
0023 #ifndef genfit_AbsHMatrix_h
0024 #define genfit_AbsHMatrix_h
0025
0026 #include <TObject.h>
0027 #include <TMatrixDSym.h>
0028 #include <TVectorD.h>
0029
0030
0031 namespace genfit {
0032
0033
0034
0035
0036
0037 class AbsHMatrix : public TObject {
0038
0039 public:
0040
0041 AbsHMatrix() {;}
0042
0043 virtual ~AbsHMatrix() {;}
0044
0045
0046 virtual const TMatrixD& getMatrix() const = 0;
0047
0048
0049 virtual TVectorD Hv(const TVectorD& v) const {return getMatrix()*v;}
0050
0051
0052 virtual TMatrixD MHt(const TMatrixDSym& M) const {return TMatrixD(M, TMatrixD::kMultTranspose, getMatrix());}
0053 virtual TMatrixD MHt(const TMatrixD& M) const {return TMatrixD(M, TMatrixD::kMultTranspose, getMatrix());}
0054
0055
0056 virtual void HMHt(TMatrixDSym& M) const {M.Similarity(getMatrix());}
0057
0058 virtual AbsHMatrix* clone() const = 0;
0059
0060 bool operator==(const AbsHMatrix& other) const {return this->isEqual(other);}
0061 bool operator!=(const AbsHMatrix& other) const {return !(this->isEqual(other));}
0062 virtual bool isEqual(const AbsHMatrix& other) const = 0;
0063
0064 virtual void Print(const Option_t* = "") const {;}
0065
0066 protected:
0067
0068 AbsHMatrix(const AbsHMatrix& o) : TObject(o) {;}
0069 AbsHMatrix& operator=(const AbsHMatrix&);
0070
0071 public:
0072 ClassDef(AbsHMatrix,1)
0073
0074 };
0075
0076 }
0077
0078
0079 #endif