range2d_iterator_with_boundary_flag< I > Class Template Reference

a 2D iterator that knows its position in the 2D grid ans supports iterating over sub-ranges More...

#include <mia/2d/iterator.hh>

Inherits forward_iterator_tag.

Public Types

enum  EBoundary {
  eb_none = 0, eb_xlow = 1, eb_xhigh = 2, eb_x = 3,
  eb_ylow = 4, eb_yhigh = 8, eb_y = 0xC
}
 
typedef I internal_iterator
 data type for the real iterator in the background More...
 
typedef I::pointer pointer
 data type pointer More...
 
typedef I::reference reference
 data type reference More...
 
typedef I::value_type value_type
 

Public Member Functions

int get_boundary_flags () const
 
internal_iterator get_point ()
 
reference operator* () const
 
range2d_iterator_with_boundary_flag< I > & operator++ ()
 prefix increment More...
 
range2d_iterator_with_boundary_flag< I > operator++ (int)
 postfix increment More...
 
pointer operator-> () const
 
range2d_iterator_with_boundary_flag< I > & operator= (const range2d_iterator_with_boundary_flag< I > &other)
 assignment operator More...
 
template<typename AI >
range2d_iterator_with_boundary_flag< I > & operator= (const range2d_iterator_with_boundary_flag< AI > &other)
 
const C2DBoundspos () const
 
 range2d_iterator_with_boundary_flag ()
 
 range2d_iterator_with_boundary_flag (const C2DBounds &pos, const C2DBounds &size, const C2DBounds &start, const C2DBounds &end, I iterator)
 
 range2d_iterator_with_boundary_flag (const C2DBounds &pos)
 
 range2d_iterator_with_boundary_flag (const range2d_iterator_with_boundary_flag< I > &other)
 copy constructore More...
 
template<typename AI >
 range2d_iterator_with_boundary_flag (const range2d_iterator_with_boundary_flag< AI > &other)
 

Friends

template<typename AI >
class range2d_iterator_with_boundary_flag
 friend iterator type because we may want to copy a iterator to a const_iterator. More...
 

Detailed Description

template<typename I>
class range2d_iterator_with_boundary_flag< I >

a 2D iterator that knows its position in the 2D grid ans supports iterating over sub-ranges

Iterator to iterate over a sub-range of 2D data that is given on a grid. Two iterators are considered to be equal, if their positions are equal.

Template Parameters
theinternal iterator that is used to iterate of the original grid without skipping.

Definition at line 42 of file 2d/iterator.hh.

Member Typedef Documentation

◆ internal_iterator

template<typename I>
typedef I range2d_iterator_with_boundary_flag< I >::internal_iterator

data type for the real iterator in the background

Definition at line 49 of file 2d/iterator.hh.

◆ pointer

template<typename I>
typedef I::pointer range2d_iterator_with_boundary_flag< I >::pointer

data type pointer

Definition at line 47 of file 2d/iterator.hh.

◆ reference

template<typename I>
typedef I::reference range2d_iterator_with_boundary_flag< I >::reference

data type reference

Definition at line 45 of file 2d/iterator.hh.

◆ value_type

template<typename I>
typedef I::value_type range2d_iterator_with_boundary_flag< I >::value_type

Definition at line 51 of file 2d/iterator.hh.

Member Enumeration Documentation

◆ EBoundary

Enumerate to describe the various positions on the domain boundarys. These boundaries correspond to the full domain of the data, not to the sub-range this iteratior works on. I.e. if the sub-range is a subset of the open domain (i.e. without its boundary) then the iterator will never touch the domain boundary.

Enumerator
eb_none 

no boundary

eb_xlow 

at low x-boundary

eb_xhigh 

at high x-boundary

eb_x 

at one of the x-boundaries

eb_ylow 

at low y-boundary

eb_yhigh 

at high y-boundary

eb_y 

at one of the y-boundaries

Definition at line 60 of file 2d/iterator.hh.

Constructor & Destructor Documentation

◆ range2d_iterator_with_boundary_flag() [1/5]

standard constructor

◆ range2d_iterator_with_boundary_flag() [2/5]

template<typename I>
range2d_iterator_with_boundary_flag< I >::range2d_iterator_with_boundary_flag ( const C2DBounds pos,
const C2DBounds size,
const C2DBounds start,
const C2DBounds end,
iterator 
)

Full constructor of the range iterator

Parameters
positerator position to initialize the iterator with
sizesize of the original data field
startstart of the iterator range
endend of the iterator range
iteratorthe iterator of the underlying 2D data structure

◆ range2d_iterator_with_boundary_flag() [3/5]

End iterator, can't be dereferenced This iterator is only there to define the end position of the range_iterator.

Parameters
posend position to set this iterator to.

◆ range2d_iterator_with_boundary_flag() [4/5]

copy constructore

◆ range2d_iterator_with_boundary_flag() [5/5]

template<typename I >
template<typename AI >
range2d_iterator_with_boundary_flag< I >::range2d_iterator_with_boundary_flag ( const range2d_iterator_with_boundary_flag< AI > &  other)

Constructor to construct the iterator from one that is based on another iterator type. The usual idea is that a iterator may be converted into it's const variant.

Template Parameters
AIthe other iterator type. Iterator type I must be copy-constructable from type AI
Parameters
other

Definition at line 189 of file 2d/iterator.hh.

Member Function Documentation

◆ get_boundary_flags()

template<typename I>
int range2d_iterator_with_boundary_flag< I >::get_boundary_flags ( ) const
Returns
the flags describing whether the iterator is on a domain boundary.

◆ get_point()

template<typename I>
internal_iterator range2d_iterator_with_boundary_flag< I >::get_point ( )

Return the internal iterator

◆ operator*()

template<typename I>
reference range2d_iterator_with_boundary_flag< I >::operator* ( ) const
Returns
current value the iterator points to

◆ operator++() [1/2]

template<typename I>
range2d_iterator_with_boundary_flag<I>& range2d_iterator_with_boundary_flag< I >::operator++ ( )

prefix increment

◆ operator++() [2/2]

template<typename I>
range2d_iterator_with_boundary_flag<I> range2d_iterator_with_boundary_flag< I >::operator++ ( int  )

postfix increment

◆ operator->()

template<typename I>
pointer range2d_iterator_with_boundary_flag< I >::operator-> ( ) const
Returns
pointer to the current value the iterator points to

◆ operator=() [1/2]

assignment operator

◆ operator=() [2/2]

template<typename I >
template<typename AI >
range2d_iterator_with_boundary_flag< I > & range2d_iterator_with_boundary_flag< I >::operator= ( const range2d_iterator_with_boundary_flag< AI > &  other)

Assignment operator from another type of iterator

Template Parameters
AIother iterator type. The assignment I b = a; with a of type AI must be defined.
Parameters
other

Definition at line 175 of file 2d/iterator.hh.

◆ pos()

template<typename I>
const C2DBounds& range2d_iterator_with_boundary_flag< I >::pos ( ) const
Returns
the current position within the 2D grid with respect to the full size of the grid.

Friends And Related Function Documentation

◆ range2d_iterator_with_boundary_flag

template<typename I>
template<typename AI >
friend class range2d_iterator_with_boundary_flag
friend

friend iterator type because we may want to copy a iterator to a const_iterator.

Definition at line 101 of file 2d/iterator.hh.


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