aGrUM 2.3.2
a C++ library for (probabilistic) graphical models
gum::SortedPriorityQueueIterator< Val, Priority, Cmp > Class Template Reference

Sorted priority queue iterator. More...

#include <agrum/base/core/sortedPriorityQueue.h>

Inherits SharedAVLTreeReverseIterator< Val, SortedPriorityQueue< Val, int, std::less< int > >::TreeCmp >.

Collaboration diagram for gum::SortedPriorityQueueIterator< Val, Priority, Cmp >:

Public Types

using iterator_category = std::bidirectional_iterator_tag
 Types for STL compliance.
using value_type = Val
 Types for STL compliance.
using reference = value_type&
 Types for STL compliance.
using const_reference = const value_type&
 Types for STL compliance.
using pointer = value_type*
 Types for STL compliance.
using const_pointer = const value_type*
 Types for STL compliance.
using TreeCmp = typename SortedPriorityQueue< Val, Priority, Cmp >::TreeCmp
 Types for STL compliance.

Public Member Functions

Constructors / Destructors
 SortedPriorityQueueIterator (const SortedPriorityQueue< Val, Priority, Cmp > &queue, const bool begin=true) noexcept
 constructor for begin iterators
 SortedPriorityQueueIterator (const SortedPriorityQueueIterator< Val, Priority, Cmp > &from) noexcept
 copy constructor
 SortedPriorityQueueIterator (SortedPriorityQueueIterator< Val, Priority, Cmp > &&from) noexcept
 move constructor
 ~SortedPriorityQueueIterator () noexcept
 destructor
Operators
SortedPriorityQueueIterator< Val, Priority, Cmp > & operator= (const SortedPriorityQueueIterator< Val, Priority, Cmp > &from) noexcept
 copy operator
SortedPriorityQueueIterator< Val, Priority, Cmp > & operator= (SortedPriorityQueueIterator< Val, Priority, Cmp > &&from) noexcept
 move operator
bool operator== (const SortedPriorityQueueIterator< Val, Priority, Cmp > &from) const
 indicates whether two iterator point to the same element
bool operator!= (const SortedPriorityQueueIterator< Val, Priority, Cmp > &from) const
 indicates whether two iterator point to different element
SortedPriorityQueueIterator< Val, Priority, Cmp > & operator++ () noexcept
 move to the next element in the queue
SortedPriorityQueueIterator< Val, Priority, Cmp > & operator+= (const Size k) noexcept
 move to the next k element
SortedPriorityQueueIterator< Val, Priority, Cmp > & operator-- () noexcept
 move to the preceding element in the queue
SortedPriorityQueueIterator< Val, Priority, Cmp > & operator-= (const Size k) noexcept
 move to the preceding k element
const_reference operator* () const
 returns the value pointed to by the iterator
const_pointer operator-> () const
 returns a pointer on the value pointed to by the iterator

Public Attributes

friend SortedPriorityQueue< Val, Priority, Cmp >
 allow sorted priority queues to access the content of the iterators

Detailed Description

template<typename Val, typename Priority = int, typename Cmp = std::less< Priority >>
class gum::SortedPriorityQueueIterator< Val, Priority, Cmp >

Sorted priority queue iterator.

Template Parameters
ValThe type of the elements stored into the queue.
PriorityThe type of the priorities assigned to the elements.
CmpThe function used for sorting the priorities.

Definition at line 554 of file sortedPriorityQueue.h.

Member Typedef Documentation

◆ const_pointer

template<typename Val, typename Priority = int, typename Cmp = std::less< Priority >>
using gum::SortedPriorityQueueIterator< Val, Priority, Cmp >::const_pointer = const value_type*

Types for STL compliance.

Definition at line 566 of file sortedPriorityQueue.h.

◆ const_reference

template<typename Val, typename Priority = int, typename Cmp = std::less< Priority >>
using gum::SortedPriorityQueueIterator< Val, Priority, Cmp >::const_reference = const value_type&

Types for STL compliance.

Definition at line 564 of file sortedPriorityQueue.h.

◆ iterator_category

template<typename Val, typename Priority = int, typename Cmp = std::less< Priority >>
using gum::SortedPriorityQueueIterator< Val, Priority, Cmp >::iterator_category = std::bidirectional_iterator_tag

Types for STL compliance.

Definition at line 561 of file sortedPriorityQueue.h.

◆ pointer

template<typename Val, typename Priority = int, typename Cmp = std::less< Priority >>
using gum::SortedPriorityQueueIterator< Val, Priority, Cmp >::pointer = value_type*

Types for STL compliance.

Definition at line 565 of file sortedPriorityQueue.h.

◆ reference

template<typename Val, typename Priority = int, typename Cmp = std::less< Priority >>
using gum::SortedPriorityQueueIterator< Val, Priority, Cmp >::reference = value_type&

Types for STL compliance.

Definition at line 563 of file sortedPriorityQueue.h.

◆ TreeCmp

template<typename Val, typename Priority = int, typename Cmp = std::less< Priority >>
using gum::SortedPriorityQueueIterator< Val, Priority, Cmp >::TreeCmp = typename SortedPriorityQueue< Val, Priority, Cmp >::TreeCmp

Types for STL compliance.

Definition at line 567 of file sortedPriorityQueue.h.

◆ value_type

template<typename Val, typename Priority = int, typename Cmp = std::less< Priority >>
using gum::SortedPriorityQueueIterator< Val, Priority, Cmp >::value_type = Val

Types for STL compliance.

Definition at line 562 of file sortedPriorityQueue.h.

Constructor & Destructor Documentation

◆ SortedPriorityQueueIterator() [1/3]

template<typename Val, typename Priority = int, typename Cmp = std::less< Priority >>
gum::SortedPriorityQueueIterator< Val, Priority, Cmp >::SortedPriorityQueueIterator ( const SortedPriorityQueue< Val, Priority, Cmp > & queue,
const bool begin = true )
explicitnoexcept

constructor for begin iterators

Parameters
queuethe sorted priority queue which parses the iterator
beginif true, the iterator points to the highest value in the queue, else it points to the lowest value

◆ SortedPriorityQueueIterator() [2/3]

template<typename Val, typename Priority = int, typename Cmp = std::less< Priority >>
gum::SortedPriorityQueueIterator< Val, Priority, Cmp >::SortedPriorityQueueIterator ( const SortedPriorityQueueIterator< Val, Priority, Cmp > & from)
noexcept

copy constructor

◆ SortedPriorityQueueIterator() [3/3]

template<typename Val, typename Priority = int, typename Cmp = std::less< Priority >>
gum::SortedPriorityQueueIterator< Val, Priority, Cmp >::SortedPriorityQueueIterator ( SortedPriorityQueueIterator< Val, Priority, Cmp > && from)
noexcept

move constructor

◆ ~SortedPriorityQueueIterator()

template<typename Val, typename Priority = int, typename Cmp = std::less< Priority >>
gum::SortedPriorityQueueIterator< Val, Priority, Cmp >::~SortedPriorityQueueIterator ( )
noexcept

destructor

Member Function Documentation

◆ operator!=()

template<typename Val, typename Priority = int, typename Cmp = std::less< Priority >>
bool gum::SortedPriorityQueueIterator< Val, Priority, Cmp >::operator!= ( const SortedPriorityQueueIterator< Val, Priority, Cmp > & from) const

indicates whether two iterator point to different element

◆ operator*()

template<typename Val, typename Priority = int, typename Cmp = std::less< Priority >>
const_reference gum::SortedPriorityQueueIterator< Val, Priority, Cmp >::operator* ( ) const

returns the value pointed to by the iterator

Returns
the value pointed to by the iterator, if the iterator actually points to an element
Exceptions
NotFoundis raised if the iterator points to nothing

◆ operator++()

template<typename Val, typename Priority = int, typename Cmp = std::less< Priority >>
SortedPriorityQueueIterator< Val, Priority, Cmp > & gum::SortedPriorityQueueIterator< Val, Priority, Cmp >::operator++ ( )
noexcept

move to the next element in the queue

Warning
Applying this operator to an iterator equal to the end iterator has no effect. In particular, it does not raise any exception.

◆ operator+=()

template<typename Val, typename Priority = int, typename Cmp = std::less< Priority >>
SortedPriorityQueueIterator< Val, Priority, Cmp > & gum::SortedPriorityQueueIterator< Val, Priority, Cmp >::operator+= ( const Size k)
noexcept

move to the next k element

Warning
Applying this operator to an iterator equal to the end iterator has no effect. In particular, it does not raise any exception.

◆ operator--()

template<typename Val, typename Priority = int, typename Cmp = std::less< Priority >>
SortedPriorityQueueIterator< Val, Priority, Cmp > & gum::SortedPriorityQueueIterator< Val, Priority, Cmp >::operator-- ( )
noexcept

move to the preceding element in the queue

Warning
Applying this operator to an iterator equal to the begin iterator has no effect. In particular, it does not raise any exception.

◆ operator-=()

template<typename Val, typename Priority = int, typename Cmp = std::less< Priority >>
SortedPriorityQueueIterator< Val, Priority, Cmp > & gum::SortedPriorityQueueIterator< Val, Priority, Cmp >::operator-= ( const Size k)
noexcept

move to the preceding k element

Warning
Applying this operator to an iterator equal to the begin iterator has no effect. In particular, it does not raise any exception.

◆ operator->()

template<typename Val, typename Priority = int, typename Cmp = std::less< Priority >>
const_pointer gum::SortedPriorityQueueIterator< Val, Priority, Cmp >::operator-> ( ) const

returns a pointer on the value pointed to by the iterator

◆ operator=() [1/2]

template<typename Val, typename Priority = int, typename Cmp = std::less< Priority >>
SortedPriorityQueueIterator< Val, Priority, Cmp > & gum::SortedPriorityQueueIterator< Val, Priority, Cmp >::operator= ( const SortedPriorityQueueIterator< Val, Priority, Cmp > & from)
noexcept

copy operator

◆ operator=() [2/2]

template<typename Val, typename Priority = int, typename Cmp = std::less< Priority >>
SortedPriorityQueueIterator< Val, Priority, Cmp > & gum::SortedPriorityQueueIterator< Val, Priority, Cmp >::operator= ( SortedPriorityQueueIterator< Val, Priority, Cmp > && from)
noexcept

move operator

◆ operator==()

template<typename Val, typename Priority = int, typename Cmp = std::less< Priority >>
bool gum::SortedPriorityQueueIterator< Val, Priority, Cmp >::operator== ( const SortedPriorityQueueIterator< Val, Priority, Cmp > & from) const

indicates whether two iterator point to the same element

Member Data Documentation

◆ SortedPriorityQueue< Val, Priority, Cmp >

template<typename Val, typename Priority = int, typename Cmp = std::less< Priority >>
friend gum::SortedPriorityQueueIterator< Val, Priority, Cmp >::SortedPriorityQueue< Val, Priority, Cmp >

allow sorted priority queues to access the content of the iterators

Definition at line 658 of file sortedPriorityQueue.h.


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