ROOT logo
HYDRA - THE HADES ANALYSIS PACKAGE » (UNKNOWN) » HKalMatrixTools

class HKalMatrixTools: public TObject

_HADES_CLASS_DESCRIPTION


 Some helper functions for matrices.



Function Members (Methods)

public:
HKalMatrixTools()
HKalMatrixTools(const HKalMatrixTools&)
virtual~HKalMatrixTools()
voidTObject::AbstractMethod(const char* method) const
virtual voidTObject::AppendPad(Option_t* option = "")
virtual voidTObject::Browse(TBrowser* b)
static Bool_tcheckCond(const TMatrixD& M)
static Int_tcheckSymmetry(TMatrixD& M, Double_t tol)
static Bool_tcheckValidElems(const TMatrixD& M)
static TClass*Class()
virtual const char*TObject::ClassName() const
virtual voidTObject::Clear(Option_t* = "")
virtual TObject*TObject::Clone(const char* newname = "") const
virtual Int_tTObject::Compare(const TObject* obj) const
virtual voidTObject::Copy(TObject& object) const
static Bool_tdecomposeUD(TMatrixD& M)
virtual voidTObject::Delete(Option_t* option = "")MENU
virtual Int_tTObject::DistancetoPrimitive(Int_t px, Int_t py)
virtual voidTObject::Draw(Option_t* option = "")
virtual voidTObject::DrawClass() constMENU
virtual TObject*TObject::DrawClone(Option_t* option = "") constMENU
virtual voidTObject::Dump() constMENU
virtual voidTObject::Error(const char* method, const char* msgfmt) const
virtual voidTObject::Execute(const char* method, const char* params, Int_t* error = 0)
virtual voidTObject::Execute(TMethod* method, TObjArray* params, Int_t* error = 0)
virtual voidTObject::ExecuteEvent(Int_t event, Int_t px, Int_t py)
virtual voidTObject::Fatal(const char* method, const char* msgfmt) const
virtual TObject*TObject::FindObject(const char* name) const
virtual TObject*TObject::FindObject(const TObject* obj) const
virtual Option_t*TObject::GetDrawOption() const
static Long_tTObject::GetDtorOnly()
virtual const char*TObject::GetIconName() const
virtual const char*TObject::GetName() const
virtual char*TObject::GetObjectInfo(Int_t px, Int_t py) const
static Bool_tTObject::GetObjectStat()
virtual Option_t*TObject::GetOption() const
virtual const char*TObject::GetTitle() const
virtual UInt_tTObject::GetUniqueID() const
virtual Bool_tTObject::HandleTimer(TTimer* timer)
virtual ULong_tTObject::Hash() const
virtual voidTObject::Info(const char* method, const char* msgfmt) const
virtual Bool_tTObject::InheritsFrom(const char* classname) const
virtual Bool_tTObject::InheritsFrom(const TClass* cl) const
virtual voidTObject::Inspect() constMENU
voidTObject::InvertBit(UInt_t f)
virtual TClass*IsA() const
virtual Bool_tTObject::IsEqual(const TObject* obj) const
virtual Bool_tTObject::IsFolder() const
Bool_tTObject::IsOnHeap() const
static Bool_tisPosDef(const TMatrixD& M)
virtual Bool_tTObject::IsSortable() const
Bool_tTObject::IsZombie() const
virtual voidTObject::ls(Option_t* option = "") const
static Bool_tmakeSymmetric(TMatrixD& M)
voidTObject::MayNotUse(const char* method) const
virtual Bool_tTObject::Notify()
voidTObject::Obsolete(const char* method, const char* asOfVers, const char* removedFromVers) const
static voidTObject::operator delete(void* ptr)
static voidTObject::operator delete(void* ptr, void* vp)
static voidTObject::operator delete[](void* ptr)
static voidTObject::operator delete[](void* ptr, void* vp)
void*TObject::operator new(size_t sz)
void*TObject::operator new(size_t sz, void* vp)
void*TObject::operator new[](size_t sz)
void*TObject::operator new[](size_t sz, void* vp)
HKalMatrixTools&operator=(const HKalMatrixTools&)
virtual voidTObject::Paint(Option_t* option = "")
virtual voidTObject::Pop()
virtual voidTObject::Print(Option_t* option = "") const
virtual Int_tTObject::Read(const char* name)
virtual voidTObject::RecursiveRemove(TObject* obj)
voidTObject::ResetBit(UInt_t f)
static Bool_tresolveUD(TMatrixD& U, TMatrixD& D, const TMatrixD& UD)
virtual voidTObject::SaveAs(const char* filename = "", Option_t* option = "") constMENU
virtual voidTObject::SavePrimitive(ostream& out, Option_t* option = "")
voidTObject::SetBit(UInt_t f)
voidTObject::SetBit(UInt_t f, Bool_t set)
virtual voidTObject::SetDrawOption(Option_t* option = "")MENU
static voidTObject::SetDtorOnly(void* obj)
static voidTObject::SetObjectStat(Bool_t stat)
virtual voidTObject::SetUniqueID(UInt_t uid)
virtual voidShowMembers(TMemberInspector&)
virtual voidStreamer(TBuffer&)
voidStreamerNVirtual(TBuffer& ClassDef_StreamerNVirtual_b)
virtual voidTObject::SysError(const char* method, const char* msgfmt) const
Bool_tTObject::TestBit(UInt_t f) const
Int_tTObject::TestBits(UInt_t f) const
virtual voidTObject::UseCurrentStyle()
virtual voidTObject::Warning(const char* method, const char* msgfmt) const
virtual Int_tTObject::Write(const char* name = 0, Int_t option = 0, Int_t bufsize = 0)
virtual Int_tTObject::Write(const char* name = 0, Int_t option = 0, Int_t bufsize = 0) const
protected:
virtual voidTObject::DoError(int level, const char* location, const char* fmt, va_list va) const
voidTObject::MakeZombie()

Data Members

Class Charts

Inheritance Inherited Members Includes Libraries
Class Charts

Function documentation

Int_t checkSymmetry(TMatrixD& M, Double_t tol)
 Mind the meaning of the return value!

 Checks if input matrix M is (close to) symmetric.
 Returns the amount of off-diagonal elements that were not
 symmetric. Therefore a return value of 0 means the matrix
 is symmetric!
 For non quadratic matrices -1 will be returned.

 Input:
 M:   The matrix to check.
 tol: The allowed relative difference between diagonal
      elements so that the matrix is still seen as symmetric.
Bool_t checkCond(const TMatrixD& M)
 Calculate matrix condition using singular values.
Bool_t decomposeUD(TMatrixD& M)
 A matrix can be written as the product M = U*D*U^T where
 U is an upper triangular and D a diagonal matrix.
 This function calculates the U and D factors of the input
 matrix M. Both U and D can be stored in a single matrix.
 Since the diagonal elements of U are always 1, they are
 not explicitly stored and replaced by the elements of D.

 The input matrix M will be overwritten.
Bool_t isPosDef(const TMatrixD& M)
 Returns true if matrix is positive definite, i.e. all eigenvalues are
 real and greater than zero.
Bool_t checkValidElems(const TMatrixD& M)
 Check for INFs and NaNs in matrix.
Bool_t makeSymmetric(TMatrixD& M)
 Produce a valid symmetric matrix out of an almost symmetric TMatrixD
 Input matrix M will be overwritten!
Bool_t resolveUD(TMatrixD& U, TMatrixD& D, const TMatrixD& UD)
 Input is a matrix where the U and D factors are stored in a single
 matrix.

 Extracts the U and D matrices as two separate objects from the input
 matrix.
 output:
 U: upper triangular matrix.
 D: diagonal matrix.
 input:
 UD: The U and D factors are stored in this single matrix.
HKalMatrixTools()
{ }
virtual ~HKalMatrixTools()
{ }