GNU g++  v5.2.1
GNU Standard C++
__gnu_parallel::_LoserTreeBase< _Tp, _Compare > Class Template Reference

Guarded loser/tournament tree. More...

#include <losertree.h>

Inheritance diagram for __gnu_parallel::_LoserTreeBase< _Tp, _Compare >:
Collaboration diagram for __gnu_parallel::_LoserTreeBase< _Tp, _Compare >:

Classes

struct  _Loser
 Internal representation of a _LoserTree element. More...
 

Public Member Functions

 _LoserTreeBase (unsigned int __k, _Compare __comp)
 The constructor. More...
 
 ~_LoserTreeBase ()
 The destructor. More...
 
int __get_min_source ()
 
void __insert_start (const _Tp &__key, int __source, bool __sup)
 Initializes the sequence "_M_source" with the element "__key". More...
 

Protected Attributes

_Compare _M_comp
 _Compare to use. More...
 
bool _M_first_insert
 State flag that determines whether the _LoserTree is empty. More...
 
unsigned int _M_ik
 
unsigned int _M_k
 
unsigned int _M_log_k
 log_2{_M_k} More...
 
_Loser_M_losers
 _LoserTree __elements. More...
 
unsigned int _M_offset
 

Detailed Description

template<typename _Tp, typename _Compare>
class __gnu_parallel::_LoserTreeBase< _Tp, _Compare >

Guarded loser/tournament tree.

The smallest element is at the top.

Guarding is done explicitly through one flag _M_sup per element, inf is not needed due to a better initialization routine. This is a well-performing variant.

Parameters
_Tpthe element type
_Comparethe comparator to use, defaults to std::less<_Tp>

Constructor & Destructor Documentation

template<typename _Tp , typename _Compare >
__gnu_parallel::_LoserTreeBase< _Tp, _Compare >::_LoserTreeBase ( unsigned int  __k,
_Compare  __comp 
)
inline

The constructor.

Parameters
__kThe number of sequences to merge.
__compThe comparator to use.

References __gnu_parallel::__rd_log2(), __gnu_parallel::_LoserTreeBase< _Tp, _Compare >::_M_k, and __gnu_parallel::_LoserTreeBase< _Tp, _Compare >::_M_log_k.

Here is the call graph for this function:

template<typename _Tp , typename _Compare >
__gnu_parallel::_LoserTreeBase< _Tp, _Compare >::~_LoserTreeBase ( )
inline

Member Function Documentation

template<typename _Tp , typename _Compare >
int __gnu_parallel::_LoserTreeBase< _Tp, _Compare >::__get_min_source ( )
inline
Returns
the index of the sequence with the smallest element.

References __gnu_parallel::_LoserTreeBase< _Tp, _Compare >::_Loser::_M_source.

template<typename _Tp , typename _Compare >
void __gnu_parallel::_LoserTreeBase< _Tp, _Compare >::__insert_start ( const _Tp &  __key,
int  __source,
bool  __sup 
)
inline

Initializes the sequence "_M_source" with the element "__key".

Parameters
__keythe element to insert
__source__index of the __source __sequence
__supflag that determines whether the value to insert is an explicit __supremum.

References __gnu_parallel::_LoserTreeBase< _Tp, _Compare >::_M_k, __gnu_parallel::_LoserTreeBase< _Tp, _Compare >::_Loser::_M_key, __gnu_parallel::_LoserTreeBase< _Tp, _Compare >::_Loser::_M_source, and __gnu_parallel::_LoserTreeBase< _Tp, _Compare >::_Loser::_M_sup.

Member Data Documentation

template<typename _Tp , typename _Compare >
bool __gnu_parallel::_LoserTreeBase< _Tp, _Compare >::_M_first_insert
protected

State flag that determines whether the _LoserTree is empty.

Only used for building the _LoserTree.

template<typename _Tp , typename _Compare >
unsigned int __gnu_parallel::_LoserTreeBase< _Tp, _Compare >::_M_ik
protected
template<typename _Tp , typename _Compare >
unsigned int __gnu_parallel::_LoserTreeBase< _Tp, _Compare >::_M_log_k
protected
template<typename _Tp , typename _Compare >
unsigned int __gnu_parallel::_LoserTreeBase< _Tp, _Compare >::_M_offset
protected

The documentation for this class was generated from the following file: