|   | ROOT   6.16/01 Reference Guide | 
| Classes | |
| class | RVec | 
| A "std::vector"-like collection of values implementing handy operation to analyse them.  More... | |
| Functions | |
| template<typename T > | |
| auto | All (const RVec< T > &v) -> decltype(v[0]==false) | 
| Return true if all of the elements equate to true, return false otherwise.  More... | |
| template<typename T > | |
| auto | Any (const RVec< T > &v) -> decltype(v[0]==true) | 
| Return true if any of the elements equates to true, return false otherwise.  More... | |
| template<typename T > | |
| RVec< typename RVec< T >::size_type > | Argsort (const RVec< T > &v) | 
| Return an RVec of indices that sort the input RVec.  More... | |
| template<typename T > | |
| RVec< RVec< typename RVec< T >::size_type > > | Combinations (const RVec< T > &v, const typename RVec< T >::size_type n) | 
| Return the indices that represent all unique combinations of the elements of a given RVec.  More... | |
| template<typename T1 , typename T2 > | |
| RVec< RVec< typename RVec< T1 >::size_type > > | Combinations (const RVec< T1 > &v1, const RVec< T2 > &v2) | 
| Return the indices that represent all combinations of the elements of two RVecs.  More... | |
| template<typename T , typename V > | |
| auto | Dot (const RVec< T > &v0, const RVec< V > &v1) -> decltype(v0[0] *v1[0]) | 
| Inner product.  More... | |
| template<typename T , typename F > | |
| RVec< T > | Filter (const RVec< T > &v, F &&f) | 
| Create a new collection with the elements passing the filter expressed by the predicate.  More... | |
| template<typename T > | |
| RVec< T > | Intersect (const RVec< T > &v1, const RVec< T > &v2, bool v2_is_sorted=false) | 
| Return the intersection of elements of two RVecs.  More... | |
| template<typename T , typename F > | |
| auto | Map (const RVec< T > &v, F &&f) -> RVec< decltype(f(v[0]))> | 
| Create new collection applying a callable to the elements of the input collection.  More... | |
| template<typename T > | |
| double | Mean (const RVec< T > &v) | 
| Get the mean of the elements of an RVec.  More... | |
| template<typename T > | |
| RVec< typename RVec< T >::size_type > | Nonzero (const RVec< T > &v) | 
| Return the indices of the elements which are not zero.  More... | |
| template<class T > | |
| std::ostream & | operator<< (std::ostream &os, const RVec< T > &v) | 
| Print a RVec at the prompt:  More... | |
| template<typename T > | |
| RVec< T > | Reverse (const RVec< T > &v) | 
| Return copy of reversed vector.  More... | |
| template<typename T > | |
| RVec< T > | Sort (const RVec< T > &v) | 
| Return copy of RVec with elements sorted in ascending order.  More... | |
| template<typename T , typename Compare > | |
| RVec< T > | Sort (const RVec< T > &v, Compare &&c) | 
| Return copy of RVec with elements sorted based on a comparison operator.  More... | |
| template<typename T > | |
| double | StdDev (const RVec< T > &v) | 
| Get the standard deviation of the elements of an RVec.  More... | |
| template<typename T > | |
| T | Sum (const RVec< T > &v) | 
| Sum elements of an RVec.  More... | |
| template<typename T > | |
| void | swap (RVec< T > &lhs, RVec< T > &rhs) | 
| template<typename T > | |
| RVec< T > | Take (const RVec< T > &v, const int n) | 
| Return first or last nelements of an RVec.  More... | |
| template<typename T > | |
| RVec< T > | Take (const RVec< T > &v, const RVec< typename RVec< T >::size_type > &i) | 
| Return elements of a vector at given indices.  More... | |
| template<typename T > | |
| double | Var (const RVec< T > &v) | 
| Get the variance of the elements of an RVec.  More... | |
| template<typename T > | |
| RVec< T > | Where (const RVec< int > &c, const RVec< T > &v1, const RVec< T > &v2) | 
| Return the elements of v1 if the condition c is true and v2 if the condition c is false.  More... | |
| template<typename T > | |
| RVec< T > | Where (const RVec< int > &c, const RVec< T > &v1, T v2) | 
| Return the elements of v1 if the condition c is true and sets the value v2 if the condition c is false.  More... | |
| template<typename T > | |
| RVec< T > | Where (const RVec< int > &c, T v1, const RVec< T > &v2) | 
| Return the elements of v2 if the condition c is false and sets the value v1 if the condition c is true.  More... | |
| template<typename T > | |
| RVec< T > | Where (const RVec< int > &c, T v1, T v2) | 
| Return a vector with the value v2 if the condition c is false and sets the value v1 if the condition c is true.  More... | |
Return true if all of the elements equate to true, return false otherwise.
Example code, at the ROOT prompt:
Return true if any of the elements equates to true, return false otherwise.
Example code, at the ROOT prompt:
| RVec< typename RVec< T >::size_type > ROOT::VecOps::Argsort | ( | const RVec< T > & | v | ) | 
Return an RVec of indices that sort the input RVec.
Example code, at the ROOT prompt:
| RVec< RVec< typename RVec< T >::size_type > > ROOT::VecOps::Combinations | ( | const RVec< T > & | v, | 
| const typename RVec< T >::size_type | n | ||
| ) | 
Return the indices that represent all unique combinations of the elements of a given RVec.
| RVec< RVec< typename RVec< T1 >::size_type > > ROOT::VecOps::Combinations | ( | const RVec< T1 > & | v1, | 
| const RVec< T2 > & | v2 | ||
| ) | 
Return the indices that represent all combinations of the elements of two RVecs.
The type of the return value is an RVec of two RVecs containing indices.
Example code, at the ROOT prompt:
| auto ROOT::VecOps::Dot | ( | const RVec< T > & | v0, | 
| const RVec< V > & | v1 | ||
| ) | -> decltype(v0[0] * v1[0]) | 
Inner product.
Example code, at the ROOT prompt:
Create a new collection with the elements passing the filter expressed by the predicate.
Example code, at the ROOT prompt:
| RVec< T > ROOT::VecOps::Intersect | ( | const RVec< T > & | v1, | 
| const RVec< T > & | v2, | ||
| bool | v2_is_sorted = false | ||
| ) | 
Return the intersection of elements of two RVecs.
Each element of v1 is looked up in v2 and added to the returned vector if found. Following, the order of v1 is preserved. If v2 is already sorted, the optional argument v2_is_sorted can be used to toggle of the internal sorting step, therewith optimising runtime.
Example code, at the ROOT prompt:
| auto ROOT::VecOps::Map | ( | const RVec< T > & | v, | 
| F && | f | ||
| ) | -> RVec<decltype(f(v[0]))> | 
Create new collection applying a callable to the elements of the input collection.
Example code, at the ROOT prompt:
| double ROOT::VecOps::Mean | ( | const RVec< T > & | v | ) | 
Get the mean of the elements of an RVec.
The return type is a double precision floating point number. Example code, at the ROOT prompt:
| RVec< typename RVec< T >::size_type > ROOT::VecOps::Nonzero | ( | const RVec< T > & | v | ) | 
Return the indices of the elements which are not zero.
Example code, at the ROOT prompt:
| std::ostream & ROOT::VecOps::operator<< | ( | std::ostream & | os, | 
| const RVec< T > & | v | ||
| ) | 
Return copy of reversed vector.
Example code, at the ROOT prompt:
Return copy of RVec with elements sorted in ascending order.
This helper is different from ArgSort since it does not return an RVec of indices, but an RVec of values.
Example code, at the ROOT prompt:
| RVec< T > ROOT::VecOps::Sort | ( | const RVec< T > & | v, | 
| Compare && | c | ||
| ) | 
Return copy of RVec with elements sorted based on a comparison operator.
The comparison operator has to fullfill the same requirements of the predicate of by std::sort.
This helper is different from ArgSort since it does not return an RVec of indices, but an RVec of values.
Example code, at the ROOT prompt:
| double ROOT::VecOps::StdDev | ( | const RVec< T > & | v | ) | 
Get the standard deviation of the elements of an RVec.
The return type is a double precision floating point number. Example code, at the ROOT prompt:
| T ROOT::VecOps::Sum | ( | const RVec< T > & | v | ) | 
Sum elements of an RVec.
Example code, at the ROOT prompt:
Return first or last n elements of an RVec. 
if n > 0 and last elements if n < 0.
Example code, at the ROOT prompt:
| RVec< T > ROOT::VecOps::Take | ( | const RVec< T > & | v, | 
| const RVec< typename RVec< T >::size_type > & | i | ||
| ) | 
Return elements of a vector at given indices.
Example code, at the ROOT prompt:
| double ROOT::VecOps::Var | ( | const RVec< T > & | v | ) | 
Get the variance of the elements of an RVec.
The return type is a double precision floating point number. Example code, at the ROOT prompt:
| RVec< T > ROOT::VecOps::Where | ( | const RVec< int > & | c, | 
| const RVec< T > & | v1, | ||
| const RVec< T > & | v2 | ||
| ) | 
Return the elements of v1 if the condition c is true and v2 if the condition c is false.
Example code, at the ROOT prompt:
| RVec< T > ROOT::VecOps::Where | ( | const RVec< int > & | c, | 
| const RVec< T > & | v1, | ||
| T | v2 | ||
| ) | 
Return the elements of v1 if the condition c is true and sets the value v2 if the condition c is false.
Example code, at the ROOT prompt:
| RVec< T > ROOT::VecOps::Where | ( | const RVec< int > & | c, | 
| T | v1, | ||
| const RVec< T > & | v2 | ||
| ) | 
Return the elements of v2 if the condition c is false and sets the value v1 if the condition c is true.
Example code, at the ROOT prompt:
Return a vector with the value v2 if the condition c is false and sets the value v1 if the condition c is true.
Example code, at the ROOT prompt: