Logo ROOT  
Reference Guide
 
Loading...
Searching...
No Matches
TMatrixTLazy.h
Go to the documentation of this file.
1// @(#)root/matrix:$Id$
2// Authors: Fons Rademakers, Eddy Offermann Nov 2003
3
4/*************************************************************************
5 * Copyright (C) 1995-2000, Rene Brun and Fons Rademakers. *
6 * All rights reserved. *
7 * *
8 * For the licensing terms see $ROOTSYS/LICENSE. *
9 * For the list of contributors see $ROOTSYS/README/CREDITS. *
10 *************************************************************************/
11
12#ifndef ROOT_TMatrixTLazy
13#define ROOT_TMatrixTLazy
14
15//////////////////////////////////////////////////////////////////////////
16// //
17// Templates of Lazy Matrix classes. //
18// //
19// TMatrixTLazy //
20// TMatrixTSymLazy //
21// THaarMatrixT //
22// THilbertMatrixT //
23// THilbertMatrixTSym //
24// //
25//////////////////////////////////////////////////////////////////////////
26
27#include "TMatrixTBase.h"
28
29template<class Element> class TVectorT;
30template<class Element> class TMatrixTBase;
31template<class Element> class TMatrixT;
32template<class Element> class TMatrixTSym;
33
34//////////////////////////////////////////////////////////////////////////
35// //
36// TMatrixTLazy //
37// //
38// Class used to make a lazy copy of a matrix, i.e. only copy matrix //
39// when really needed (when accessed). //
40// //
41//////////////////////////////////////////////////////////////////////////
42
43template<class Element> class TMatrixTLazy : public TObject {
44
45friend class TMatrixTBase<Element>;
46friend class TMatrixT <Element>;
47friend class TVectorT <Element>;
48
49protected:
54
57
58private:
59 virtual void FillIn(TMatrixT<Element> &m) const = 0;
60
61public:
63 TMatrixTLazy(Int_t nrows, Int_t ncols)
64 : fRowUpb(nrows-1),fRowLwb(0),fColUpb(ncols-1),fColLwb(0) { }
65 TMatrixTLazy(Int_t row_lwb,Int_t row_upb,Int_t col_lwb,Int_t col_upb)
66 : fRowUpb(row_upb),fRowLwb(row_lwb),fColUpb(col_upb),fColLwb(col_lwb) { }
67 ~TMatrixTLazy() override {}
68
69 inline Int_t GetRowLwb() const { return fRowLwb; }
70 inline Int_t GetRowUpb() const { return fRowUpb; }
71 inline Int_t GetColLwb() const { return fColLwb; }
72 inline Int_t GetColUpb() const { return fColUpb; }
73
74 ClassDefOverride(TMatrixTLazy,3) // Template of Lazy Matrix class
75};
76
77//////////////////////////////////////////////////////////////////////////
78// //
79// TMatrixTSymLazy //
80// //
81// Class used to make a lazy copy of a matrix, i.e. only copy matrix //
82// when really needed (when accessed). //
83// //
84//////////////////////////////////////////////////////////////////////////
85
86template<class Element> class TMatrixTSymLazy : public TObject {
87
88friend class TMatrixTBase<Element>;
89friend class TMatrixTSym <Element>;
90friend class TVectorT <Element>;
91
92protected:
95
98
99private:
100 virtual void FillIn(TMatrixTSym<Element> &m) const = 0;
101
102public:
105 : fRowUpb(nrows-1),fRowLwb(0) { }
106 TMatrixTSymLazy(Int_t row_lwb,Int_t row_upb)
107 : fRowUpb(row_upb),fRowLwb(row_lwb) { }
108 ~TMatrixTSymLazy() override {}
109
110 inline Int_t GetRowLwb() const { return fRowLwb; }
111 inline Int_t GetRowUpb() const { return fRowUpb; }
112
113 ClassDefOverride(TMatrixTSymLazy,2) // Template of Lazy Symmeytric class
114};
115
116//////////////////////////////////////////////////////////////////////////
117// //
118// THaarMatrixT //
119// //
120//////////////////////////////////////////////////////////////////////////
121
122template<class Element> class THaarMatrixT: public TMatrixTLazy<Element> {
123
124private:
125 void FillIn(TMatrixT<Element> &m) const override;
126
127public:
129 THaarMatrixT(Int_t n,Int_t no_cols = 0);
130 virtual ~THaarMatrixT() {}
131
132 ClassDefOverride(THaarMatrixT,2) // Template of Haar Matrix class
133};
134
135//////////////////////////////////////////////////////////////////////////
136// //
137// THilbertMatrixT //
138// //
139//////////////////////////////////////////////////////////////////////////
140
141template<class Element> class THilbertMatrixT : public TMatrixTLazy<Element> {
142
143private:
144 void FillIn(TMatrixT<Element> &m) const override;
145
146public:
148 THilbertMatrixT(Int_t no_rows,Int_t no_cols);
149 THilbertMatrixT(Int_t row_lwb,Int_t row_upb,Int_t col_lwb,Int_t col_upb);
150 virtual ~THilbertMatrixT() {}
151
152 ClassDefOverride(THilbertMatrixT,2) // Template of Hilbert Matrix class
153};
154
155//////////////////////////////////////////////////////////////////////////
156// //
157// THilbertMatrixTSym //
158// //
159//////////////////////////////////////////////////////////////////////////
160
161template<class Element> class THilbertMatrixTSym : public TMatrixTSymLazy<Element> {
162
163private:
164 void FillIn(TMatrixTSym<Element> &m) const override;
165
166public:
168 THilbertMatrixTSym(Int_t no_rows);
169 THilbertMatrixTSym(Int_t row_lwb,Int_t row_upb);
171
172 ClassDefOverride(THilbertMatrixTSym,2) // Template of Symmetric Hilbert Matrix class
173};
174
175#endif
int Int_t
Definition RtypesCore.h:45
#define ClassDefOverride(name, id)
Definition Rtypes.h:346
virtual ~THaarMatrixT()
void FillIn(TMatrixT< Element > &m) const override
virtual ~THilbertMatrixTSym()
void FillIn(TMatrixTSym< Element > &m) const override
void FillIn(TMatrixT< Element > &m) const override
virtual ~THilbertMatrixT()
TMatrixTBase.
Templates of Lazy Matrix classes.
TMatrixTLazy(const TMatrixTLazy< Element > &)
Int_t GetColUpb() const
Int_t GetRowUpb() const
Int_t GetColLwb() const
TMatrixTLazy(Int_t nrows, Int_t ncols)
Int_t GetRowLwb() const
~TMatrixTLazy() override
virtual void FillIn(TMatrixT< Element > &m) const =0
void operator=(const TMatrixTLazy< Element > &)
TMatrixTLazy(Int_t row_lwb, Int_t row_upb, Int_t col_lwb, Int_t col_upb)
TMatrixTSymLazy(Int_t row_lwb, Int_t row_upb)
void operator=(const TMatrixTSymLazy< Element > &)
TMatrixTSymLazy(const TMatrixTSymLazy< Element > &)
~TMatrixTSymLazy() override
Int_t GetRowUpb() const
TMatrixTSymLazy(Int_t nrows)
Int_t GetRowLwb() const
virtual void FillIn(TMatrixTSym< Element > &m) const =0
TMatrixTSym.
Definition TMatrixTSym.h:36
TMatrixT.
Definition TMatrixT.h:40
Mother of all ROOT objects.
Definition TObject.h:41
TVectorT.
Definition TVectorT.h:29
const Int_t n
Definition legend1.C:16
TMarker m
Definition textangle.C:8