ROOT  6.07/01
Reference Guide
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
TVectorT.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_TVectorT
13 #define ROOT_TVectorT
14 
15 //////////////////////////////////////////////////////////////////////////
16 // //
17 // TVectorT //
18 // //
19 // Template class of Vectors in the linear algebra package //
20 // //
21 //////////////////////////////////////////////////////////////////////////
22 
23 #ifndef ROOT_TMatrixT
24 #include "TMatrixT.h"
25 #endif
26 #ifndef ROOT_TMatrixTSym
27 #include "TMatrixTSym.h"
28 #endif
29 #ifndef ROOT_TMatrixTSparse
30 #include "TMatrixTSparse.h"
31 #endif
32 
33 template<class Element> class TVectorT : public TObject {
34 
35 protected:
36  Int_t fNrows; // number of rows
37  Int_t fRowLwb; // lower bound of the row index
38  Element *fElements; //[fNrows] elements themselves
39 
40  enum {kSizeMax = 5}; // size data container on stack, see New_m(),Delete_m()
41  enum {kWorkMax = 100}; // size of work array's in several routines
42 
43  Element fDataStack[kSizeMax]; //! data container
44  Bool_t fIsOwner; //!default kTRUE, when Use array kFALSE
45 
46  Element* New_m (Int_t size);
47  void Delete_m(Int_t size,Element*&);
48  Int_t Memcpy_m(Element *newp,const Element *oldp,Int_t copySize,
49  Int_t newSize,Int_t oldSize);
50 
51  void Allocate(Int_t nrows,Int_t row_lwb = 0,Int_t init = 0);
52 
54  kStatus = BIT(14) // set if vector object is valid
55  };
56 
57 public:
58 
60  explicit TVectorT(Int_t n);
61  TVectorT(Int_t lwb,Int_t upb);
62  TVectorT(Int_t n,const Element *elements);
63  TVectorT(Int_t lwb,Int_t upb,const Element *elements);
64  TVectorT(const TVectorT <Element> &another);
68  template <class Element2> TVectorT(const TVectorT<Element2> &another)
69  {
70  R__ASSERT(another.IsValid());
71  Allocate(another.GetUpb()-another.GetLwb()+1,another.GetLwb());
72  *this = another;
73  }
74 #ifndef __CINT__
75  TVectorT(Int_t lwb,Int_t upb,Element iv1, ...);
76 #endif
77  virtual ~TVectorT() { Clear(); }
78 
79  inline Int_t GetLwb () const { return fRowLwb; }
80  inline Int_t GetUpb () const { return fNrows+fRowLwb-1; }
81  inline Int_t GetNrows () const { return fNrows; }
82  inline Int_t GetNoElements() const { return fNrows; }
83 
84  inline Element *GetMatrixArray () { return fElements; }
85  inline const Element *GetMatrixArray () const { return fElements; }
86 
87  inline void Invalidate () { SetBit(kStatus); }
88  inline void MakeValid () { ResetBit(kStatus); }
89  inline Bool_t IsValid () const { return !TestBit(kStatus); }
90  inline Bool_t IsOwner () const { return fIsOwner; }
91  inline void SetElements(const Element *elements) { R__ASSERT(IsValid());
92  memcpy(fElements,elements,fNrows*sizeof(Element)); }
93  inline TVectorT<Element> &Shift (Int_t row_shift) { fRowLwb += row_shift; return *this; }
95  inline TVectorT<Element> &ResizeTo (Int_t n) { return ResizeTo(0,n-1); }
96  inline TVectorT<Element> &ResizeTo (const TVectorT<Element> &v) { return ResizeTo(v.GetLwb(),v.GetUpb()); }
97 
98  TVectorT<Element> &Use (Int_t lwb,Int_t upb,Element *data);
99  const TVectorT<Element> &Use (Int_t lwb,Int_t upb,const Element *data) const
100  { return (const TVectorT<Element>&)(const_cast<TVectorT<Element> *>(this))->Use(lwb,upb,const_cast<Element *>(data)); }
101  TVectorT<Element> &Use (Int_t n,Element *data);
102  const TVectorT<Element> &Use (Int_t n,const Element *data) const ;
104  const TVectorT<Element> &Use (const TVectorT<Element> &v) const ;
105 
106  TVectorT<Element> &GetSub (Int_t row_lwb,Int_t row_upb,TVectorT<Element> &target,Option_t *option="S") const;
107  TVectorT<Element> GetSub (Int_t row_lwb,Int_t row_upb,Option_t *option="S") const;
108  TVectorT<Element> &SetSub (Int_t row_lwb,const TVectorT<Element> &source);
109 
116 
117  Element Norm1 () const;
118  Element Norm2Sqr() const;
119  Element NormInf () const;
120  Int_t NonZeros() const;
121  Element Sum () const;
122  Element Min () const;
123  Element Max () const;
124 
125  inline const Element &operator()(Int_t index) const;
126  inline Element &operator()(Int_t index);
127  inline const Element &operator[](Int_t index) const { return (*this)(index); }
128  inline Element &operator[](Int_t index) { return (*this)(index); }
129 
136  template <class Element2> TVectorT<Element> &operator= (const TVectorT<Element2> &source)
137  {
138  if (!AreCompatible(*this,source)) {
139  Error("operator=(const TVectorT2 &)","vectors not compatible");
140  return *this;
141  }
142 
143  TObject::operator=(source);
144  const Element2 * const ps = source.GetMatrixArray();
145  Element * const pt = GetMatrixArray();
146  for (Int_t i = 0; i < this->fNrows; i++)
147  pt[i] = ps[i];
148  return *this;
149  }
150 
151  TVectorT<Element> &operator= (Element val);
152  TVectorT<Element> &operator+=(Element val);
153  TVectorT<Element> &operator-=(Element val);
154  TVectorT<Element> &operator*=(Element val);
155 
161 
162  Bool_t operator==(Element val) const;
163  Bool_t operator!=(Element val) const;
164  Bool_t operator< (Element val) const;
165  Bool_t operator<=(Element val) const;
166  Bool_t operator> (Element val) const;
167  Bool_t operator>=(Element val) const;
168 
171  void AddSomeConstant (Element val,const TVectorT<Element> &select);
172 
173  void Randomize (Element alpha,Element beta,Double_t &seed);
174 
177 
178  void Add(const TVectorT<Element> &v);
179  void Add(const TVectorT<Element> &v1, const TVectorT<Element> &v2);
180  void Clear(Option_t * /*option*/ ="") { if (fIsOwner) Delete_m(fNrows,fElements);
181  else fElements = 0; fNrows = 0; }
182  void Draw (Option_t *option=""); // *MENU*
183  void Print(Option_t *option="") const; // *MENU*
184 
185  ClassDef(TVectorT,4) // Template of Vector class
186 };
187 
188 #ifndef __CINT__
189 // When building with -fmodules, it instantiates all pending instantiations,
190 // instead of delaying them until the end of the translation unit.
191 // We 'got away with' probably because the use and the definition of the
192 // explicit specialization do not occur in the same TU.
193 //
194 // In case we are building with -fmodules, we need to forward declare the
195 // specialization in order to compile the dictionary G__Matrix.cxx.
196 template <> TClass *TVectorT<double>::Class();
197 #endif // __CINT__
198 
199 template<class Element> inline TVectorT<Element> &TVectorT<Element>::Use (Int_t n,Element *data) { return Use(0,n-1,data); }
200 template<class Element> inline const TVectorT<Element> &TVectorT<Element>::Use (Int_t n,const Element *data) const { return Use(0,n-1,data); }
201 template<class Element> inline TVectorT<Element> &TVectorT<Element>::Use (TVectorT &v)
202  {
203  R__ASSERT(v.IsValid());
204  return Use(v.GetLwb(),v.GetUpb(),v.GetMatrixArray());
205  }
206 template<class Element> inline const TVectorT<Element> &TVectorT<Element>::Use (const TVectorT &v) const
207  {
208  R__ASSERT(v.IsValid());
209  return Use(v.GetLwb(),v.GetUpb(),v.GetMatrixArray());
210  }
211 template<class Element> inline TVectorT<Element> TVectorT<Element>::GetSub (Int_t row_lwb,Int_t row_upb,Option_t *option) const
212  {
213  TVectorT tmp;
214  this->GetSub(row_lwb,row_upb,tmp,option);
215  return tmp;
216  }
217 
218 template<class Element> inline const Element &TVectorT<Element>::operator()(Int_t ind) const
219 {
220  // Access a vector element.
221 
222  R__ASSERT(IsValid());
223  const Int_t aind = ind-fRowLwb;
224  if (aind >= fNrows || aind < 0) {
225  Error("operator()","Request index(%d) outside vector range of %d - %d",ind,fRowLwb,fRowLwb+fNrows);
227  }
228 
229  return fElements[aind];
230 }
231 template<class Element> inline Element &TVectorT<Element>::operator()(Int_t ind)
232 {
233  // Access a vector element.
234 
235  R__ASSERT(IsValid());
236  const Int_t aind = ind-fRowLwb;
237  if (aind >= fNrows || aind < 0) {
238  Error("operator()","Request index(%d) outside vector range of %d - %d",ind,fRowLwb,fRowLwb+fNrows);
240  }
241 
242  return fElements[aind];
243 }
244 
245 template<class Element> Bool_t operator== (const TVectorT <Element> &source1,const TVectorT <Element> &source2);
246 template<class Element> TVectorT<Element> operator+ (const TVectorT <Element> &source1,const TVectorT <Element> &source2);
247 template<class Element> TVectorT<Element> operator- (const TVectorT <Element> &source1,const TVectorT <Element> &source2);
248 template<class Element> Element operator* (const TVectorT <Element> &source1,const TVectorT <Element> &source2);
249 template<class Element> TVectorT<Element> operator* (const TMatrixT <Element> &a, const TVectorT <Element> &source);
250 template<class Element> TVectorT<Element> operator* (const TMatrixTSym <Element> &a, const TVectorT <Element> &source);
251 template<class Element> TVectorT<Element> operator* (const TMatrixTSparse<Element> &a, const TVectorT <Element> &source);
252 template<class Element> TVectorT<Element> operator* ( Element val, const TVectorT <Element> &source);
253 template<class Element>
254 inline
255 TVectorT<Element> operator* (const TVectorT <Element> &source, Element val) { return val * source; }
256 
257 template<class Element> Element Dot (const TVectorT <Element> &source1,const TVectorT <Element> &source2);
258 template <class Element1,class Element2>
260 template <class Element1,class Element2,class Element3>
262 template <class Element1,class Element2,class Element3>
263  Element1 Mult (const TVectorT <Element1> &v1, const TMatrixT <Element2> &m, const TVectorT <Element3> &v2);
264 
265 template<class Element> TVectorT<Element> &Add ( TVectorT <Element> &target, Element scalar, const TVectorT <Element> &source);
266 template<class Element> TVectorT<Element> &Add ( TVectorT <Element> &target, Element scalar, const TMatrixT <Element> &a,
267  const TVectorT<Element> &source);
268 template<class Element> TVectorT<Element> &Add ( TVectorT <Element> &target, Element scalar, const TMatrixTSym <Element> &a,
269  const TVectorT<Element> &source);
270 template<class Element> TVectorT<Element> &Add ( TVectorT <Element> &target, Element scalar, const TMatrixTSparse<Element> &a,
271  const TVectorT<Element> &source);
272 template<class Element> TVectorT<Element> &AddElemMult ( TVectorT <Element> &target, Element scalar, const TVectorT <Element> &source1,
273  const TVectorT <Element> &source2);
274 template<class Element> TVectorT<Element> &AddElemMult ( TVectorT <Element> &target, Element scalar, const TVectorT <Element> &source1,
275  const TVectorT <Element> &source2,const TVectorT <Element> &select);
276 template<class Element> TVectorT<Element> &AddElemDiv ( TVectorT <Element> &target, Element scalar, const TVectorT <Element> &source1,
277  const TVectorT <Element> &source2);
278 template<class Element> TVectorT<Element> &AddElemDiv ( TVectorT <Element> &target, Element scalar, const TVectorT <Element> &source1,
279  const TVectorT <Element> &source2,const TVectorT <Element> &select);
280 template<class Element> TVectorT<Element> &ElementMult ( TVectorT <Element> &target, const TVectorT <Element> &source);
281 template<class Element> TVectorT<Element> &ElementMult ( TVectorT <Element> &target, const TVectorT <Element> &source, const TVectorT <Element> &select);
282 template<class Element> TVectorT<Element> &ElementDiv ( TVectorT <Element> &target, const TVectorT <Element> &source);
283 template<class Element> TVectorT<Element> &ElementDiv ( TVectorT <Element> &target, const TVectorT <Element> &source, const TVectorT <Element> &select);
284 
285 template<class Element1,class Element2> Bool_t AreCompatible(const TVectorT<Element1> &v1,const TVectorT<Element2> &v2,Int_t verbose=0);
286 // Check matrix and vector for compatibility in multiply: M * v and v * M
287 template<class Element1,class Element2> Bool_t AreCompatible(const TMatrixT<Element1> &m, const TVectorT<Element2> &v, Int_t verbose=0);
288 template<class Element1,class Element2> Bool_t AreCompatible(const TVectorT<Element1> &v, const TMatrixT<Element2> &m, Int_t verbose=0);
289 
290 template<class Element> void Compare (const TVectorT <Element> &source1,const TVectorT <Element> &source2);
291 template<class Element> Bool_t VerifyVectorValue (const TVectorT <Element> &m, Element val,Int_t verbose, Element maxDevAllow);
292 template<class Element> Bool_t VerifyVectorValue (const TVectorT <Element> &m, Element val,Int_t verbose)
293  { return VerifyVectorValue(m,val,verbose,Element(0.0)); }
294 template<class Element> Bool_t VerifyVectorValue (const TVectorT <Element> &m, Element val)
295  { return VerifyVectorValue(m,val,1,Element(0.0)); }
296 template<class Element> Bool_t VerifyVectorIdentity (const TVectorT <Element> &m1,const TVectorT <Element> &m2, Int_t verbose, Element maxDevAllow);
297 template<class Element> Bool_t VerifyVectorIdentity (const TVectorT <Element> &m1,const TVectorT <Element> &m2, Int_t verbose)
298  { return VerifyVectorIdentity(m1,m2,verbose,Element(0.0)); }
299 template<class Element> Bool_t VerifyVectorIdentity (const TVectorT <Element> &m1,const TVectorT <Element> &m2)
300  { return VerifyVectorIdentity(m1,m2,1,Element(0.0)); }
301 
302 #endif
Element Sum() const
Compute sum of elements.
Definition: TVectorT.cxx:634
void SetElements(const Element *elements)
Definition: TVectorT.h:91
void Compare(const TVectorT< Element > &source1, const TVectorT< Element > &source2)
Compare two vectors and print out the result of the comparison.
Definition: TVectorT.cxx:2206
TVectorT< Element > & ResizeTo(Int_t lwb, Int_t upb)
Resize the vector to [lwb:upb] .
Definition: TVectorT.cxx:291
Int_t GetUpb() const
Definition: TVectorT.h:80
void Invalidate()
Definition: TVectorT.h:87
const Double_t * v1
Definition: TArcBall.cxx:33
TVectorT< Element > & operator-=(Element val)
Subtract val from every element of the vector.
Definition: TVectorT.cxx:876
TMatrixT< Element1 > OuterProduct(const TVectorT< Element1 > &v1, const TVectorT< Element2 > &v2)
Return the matrix M = v1 * v2'.
Definition: TVectorT.cxx:1492
Element Max() const
return maximum vector element value
Definition: TVectorT.cxx:663
Bool_t IsValid() const
Definition: TVectorT.h:89
const Element & operator()(Int_t index) const
Definition: TVectorT.h:218
void Add(const TVectorT< Element > &v)
Add vector v to this vector.
Definition: TVectorT.cxx:81
const char Option_t
Definition: RtypesCore.h:62
void Draw(Option_t *option="")
Draw this vector The histogram is named "TVectorT" by default and no title.
Definition: TVectorT.cxx:1350
TVectorT< Element > operator+(const TVectorT< Element > &source1, const TVectorT< Element > &source2)
Return source1+source2.
Definition: TVectorT.cxx:1409
Int_t GetNrows() const
Definition: TVectorT.h:81
#define BIT(n)
Definition: Rtypes.h:120
const Element * GetMatrixArray() const
Definition: TVectorT.h:85
Bool_t fIsOwner
data container
Definition: TVectorT.h:44
Element operator*(const TVectorT< Element > &source1, const TVectorT< Element > &source2)
Compute the scalar product.
Definition: TVectorT.cxx:1393
#define R__ASSERT(e)
Definition: TError.h:98
TVectorT< Element > & Invert()
v[i] = 1/v[i]
Definition: TVectorT.cxx:519
TVectorT< Element > & GetSub(Int_t row_lwb, Int_t row_upb, TVectorT< Element > &target, Option_t *option="S") const
Get subvector [row_lwb..row_upb]; The indexing range of the returned vector depends on the argument o...
Definition: TVectorT.cxx:370
int Int_t
Definition: RtypesCore.h:41
Element fDataStack[kSizeMax]
Definition: TVectorT.h:43
bool Bool_t
Definition: RtypesCore.h:59
TArc * a
Definition: textangle.C:12
Bool_t AreCompatible(const TVectorT< Element1 > &v1, const TVectorT< Element2 > &v2, Int_t verbose=0)
Check if v1 and v2 are both valid and have the same shape.
Definition: TVectorT.cxx:2128
TVectorT< Element > & AddElemDiv(TVectorT< Element > &target, Element scalar, const TVectorT< Element > &source1, const TVectorT< Element > &source2)
Modify addition: target += scalar * ElementDiv(source1,source2) .
Definition: TVectorT.cxx:1914
Bool_t operator>(Element val) const
Are all vector elements > val?
Definition: TVectorT.cxx:1201
TVectorT< Element > & Sqr()
Square each element of the vector.
Definition: TVectorT.cxx:479
void SetBit(UInt_t f, Bool_t set)
Set or unset the user status bits as specified in f.
Definition: TObject.cxx:732
double beta(double x, double y)
Calculates the beta function.
virtual ~TVectorT()
Definition: TVectorT.h:77
void Randomize(Element alpha, Element beta, Double_t &seed)
randomize vector elements value
Definition: TVectorT.cxx:1302
TVectorT< Element > & Use(Int_t lwb, Int_t upb, Element *data)
Use the array data to fill the vector lwb..upb].
Definition: TVectorT.cxx:346
#define ClassDef(name, id)
Definition: Rtypes.h:254
void Class()
Definition: Class.C:29
TVectorT< Element > & ElementDiv(TVectorT< Element > &target, const TVectorT< Element > &source)
Divide target by the source, element-by-element.
Definition: TVectorT.cxx:2072
TVectorT< Element > & SetSub(Int_t row_lwb, const TVectorT< Element > &source)
Insert vector source starting at [row_lwb], thereby overwriting the part [row_lwb..row_lwb+nrows_source];.
Definition: TVectorT.cxx:419
TObject & operator=(const TObject &rhs)
TObject assignment operator.
Definition: TObject.cxx:102
Element1 Mult(const TVectorT< Element1 > &v1, const TMatrixT< Element2 > &m, const TVectorT< Element3 > &v2)
Perform v1 * M * v2, a scalar result.
Definition: TVectorT.cxx:1539
void Delete_m(Int_t size, Element *&)
virtual void Error(const char *method, const char *msgfmt,...) const
Issue error message.
Definition: TObject.cxx:918
void Clear(Option_t *="")
Definition: TVectorT.h:180
const TVectorT< Element > & Use(Int_t lwb, Int_t upb, const Element *data) const
Definition: TVectorT.h:99
TVectorT< Element > & Sqrt()
Take square root of all elements.
Definition: TVectorT.cxx:497
void Error(const char *location, const char *msgfmt,...)
const Element & operator[](Int_t index) const
Definition: TVectorT.h:127
void Allocate(Int_t nrows, Int_t row_lwb=0, Int_t init=0)
Allocate new vector.
Definition: TVectorT.cxx:148
TVectorT< Element > & Shift(Int_t row_shift)
Definition: TVectorT.h:93
Element * GetMatrixArray()
Definition: TVectorT.h:84
Bool_t operator==(const TVectorT< Element > &source1, const TVectorT< Element > &source2)
Check to see if two vectors are identical.
Definition: TVectorT.cxx:1383
void Print(Option_t *option="") const
Print the vector as a list of elements.
Definition: TVectorT.cxx:1360
Bool_t operator==(Element val) const
Are all vector elements equal to val?
Definition: TVectorT.cxx:1133
Bool_t operator>=(Element val) const
Are all vector elements >= val?
Definition: TVectorT.cxx:1218
Int_t NonZeros() const
Compute the number of elements != 0.0.
Definition: TVectorT.cxx:617
TPaveText * pt
Element Min() const
return minimum vector element value
Definition: TVectorT.cxx:651
SVector< double, 2 > v
Definition: Dict.h:5
Element NormInf() const
Compute the infinity-norm of the vector MAX{ |v[i]| }.
Definition: TVectorT.cxx:600
Bool_t operator!=(Element val) const
Are all vector elements not equal to val?
Definition: TVectorT.cxx:1150
TVectorT< Element > & operator=(const TVectorT< Element > &source)
Notice that this assignment does NOT change the ownership : if the storage space was adopted...
Definition: TVectorT.cxx:677
TVectorT< Element > & operator*=(Element val)
Multiply every element of the vector with val.
Definition: TVectorT.cxx:892
TVectorT< Element > & Zero()
Set vector elements to zero.
Definition: TVectorT.cxx:450
Bool_t TestBit(UInt_t f) const
Definition: TObject.h:173
TVectorT< Element > & ElementMult(TVectorT< Element > &target, const TVectorT< Element > &source)
Multiply target by the source, element-by-element.
Definition: TVectorT.cxx:2029
TMarker * m
Definition: textangle.C:8
bool verbose
The ROOT global object gROOT contains a list of all defined classes.
Definition: TClass.h:81
void MakeValid()
Definition: TVectorT.h:88
Element Norm2Sqr() const
Compute the square of the 2-norm SUM{ v[i]^2 }.
Definition: TVectorT.cxx:581
TVectorT()
Definition: TVectorT.h:59
TVectorT< Element > & SelectNonZeros(const TVectorT< Element > &select)
Keep only element as selected through array select non-zero.
Definition: TVectorT.cxx:541
Bool_t IsOwner() const
Definition: TVectorT.h:90
Int_t GetLwb() const
Definition: TVectorT.h:79
static Int_t init()
double Double_t
Definition: RtypesCore.h:55
void select(Int_t replica=1, Int_t color=kGreen)
Definition: runplugin.C:24
Element Dot(const TVectorT< Element > &source1, const TVectorT< Element > &source2)
return inner-produvt v1 . v2
Definition: TVectorT.cxx:1475
Element Norm1() const
Compute the 1-norm of the vector SUM{ |v[i]| }.
Definition: TVectorT.cxx:564
TVectorT< Element > & ResizeTo(const TVectorT< Element > &v)
Definition: TVectorT.h:96
Bool_t operator<=(Element val) const
Are all vector elements <= val?
Definition: TVectorT.cxx:1184
Mother of all ROOT objects.
Definition: TObject.h:58
Int_t GetNoElements() const
Definition: TVectorT.h:82
Int_t fRowLwb
Definition: TVectorT.h:37
Int_t Memcpy_m(Element *newp, const Element *oldp, Int_t copySize, Int_t newSize, Int_t oldSize)
Copy copySize doubles from *oldp to *newp .
Definition: TVectorT.cxx:121
TVectorT< Element > & Add(TVectorT< Element > &target, Element scalar, const TVectorT< Element > &source)
Modify addition: target += scalar * source.
Definition: TVectorT.cxx:1584
TVectorT< Element > & AddElemMult(TVectorT< Element > &target, Element scalar, const TVectorT< Element > &source1, const TVectorT< Element > &source2)
Modify addition: target += scalar * ElementMult(source1,source2) .
Definition: TVectorT.cxx:1841
Int_t fNrows
Definition: TVectorT.h:36
TVectorT< Element > & Abs()
Take an absolute value of a vector, i.e. apply Abs() to each element.
Definition: TVectorT.cxx:461
Element & operator[](Int_t index)
Definition: TVectorT.h:128
Element * fElements
Definition: TVectorT.h:38
Bool_t MatchesNonZeroPattern(const TVectorT< Element > &select)
Check if vector elements as selected through array select are non-zero.
Definition: TVectorT.cxx:1235
static Element & NaNValue()
Bool_t VerifyVectorIdentity(const TVectorT< Element > &m1, const TVectorT< Element > &m2, Int_t verbose, Element maxDevAllow)
Verify that elements of the two vectors are equal within maxDevAllow .
Definition: TVectorT.cxx:2294
TVectorT< Element > & ResizeTo(Int_t n)
Definition: TVectorT.h:95
void ResetBit(UInt_t f)
Definition: TObject.h:172
Bool_t VerifyVectorValue(const TVectorT< Element > &m, Element val, Int_t verbose, Element maxDevAllow)
Validate that all elements of vector have value val within maxDevAllow .
Definition: TVectorT.cxx:2259
TVectorT< Element > operator-(const TVectorT< Element > &source1, const TVectorT< Element > &source2)
Return source1-source2.
Definition: TVectorT.cxx:1420
const Bool_t kTRUE
Definition: Rtypes.h:91
Element * New_m(Int_t size)
default kTRUE, when Use array kFALSE
Definition: TVectorT.cxx:64
void AddSomeConstant(Element val, const TVectorT< Element > &select)
Add to vector elements as selected through array select the value val.
Definition: TVectorT.cxx:1281
const Int_t n
Definition: legend1.C:16
Bool_t operator<(Element val) const
Are all vector elements < val?
Definition: TVectorT.cxx:1167
Bool_t SomePositive(const TVectorT< Element > &select)
Check if vector elements as selected through array select are all positive.
Definition: TVectorT.cxx:1258
TVectorT(const TVectorT< Element2 > &another)
Definition: TVectorT.h:68
TVectorT< Element > & operator+=(Element val)
Add val to every element of the vector.
Definition: TVectorT.cxx:860
TVectorT< Element > & Apply(const TElementActionT< Element > &action)
Apply action to each element of the vector.
Definition: TVectorT.cxx:1319