SLIP  1.4
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
Public Types | Public Member Functions | Static Public Attributes | Friends | List of all members
slip::Array4d< T > Class Template Reference

This is a four-dimensional dynamic and generic container. This container statisfies the BidirectionnalContainer concepts of the STL. It is also an 4d extension of the RandomAccessContainer concept. That is to say the bracket element access is replaced by the quadruple bracket element access. More...

#include <Array4d.hpp>

Public Types

typedef T value_type
 
typedef Array4d< T > self
 
typedef const Array4d< T > const_self
 
typedef value_typereference
 
typedef value_type const & const_reference
 
typedef value_typepointer
 
typedef value_type const * const_pointer
 
typedef ptrdiff_t difference_type
 
typedef std::size_t size_type
 
typedef value_typeiterator
 
typedef value_type const * const_iterator
 
typedef std::reverse_iterator
< iterator
reverse_iterator
 
typedef std::reverse_iterator
< const_iterator
const_reverse_iterator
 
typedef slip::stride_iterator
< pointer
slab_iterator
 
typedef slip::stride_iterator
< const_pointer
const_slab_iterator
 
typedef slip::stride_iterator
< pointer
slice_iterator
 
typedef slip::stride_iterator
< const_pointer
const_slice_iterator
 
typedef pointer row_iterator
 
typedef const_pointer const_row_iterator
 
typedef slip::stride_iterator
< pointer
col_iterator
 
typedef slip::stride_iterator
< const_pointer
const_col_iterator
 
typedef slip::stride_iterator
< slab_iterator
slab_range_iterator
 
typedef slip::stride_iterator
< const_slab_iterator
const_slab_range_iterator
 
typedef slip::stride_iterator
< slice_iterator
slice_range_iterator
 
typedef slip::stride_iterator
< const_slice_iterator
const_slice_range_iterator
 
typedef slip::stride_iterator
< pointer
row_range_iterator
 
typedef slip::stride_iterator
< const_pointer
const_row_range_iterator
 
typedef slip::stride_iterator
< col_iterator
col_range_iterator
 
typedef slip::stride_iterator
< const_col_iterator
const_col_range_iterator
 
typedef std::reverse_iterator
< slab_iterator
reverse_slab_iterator
 
typedef std::reverse_iterator
< const_slab_iterator
const_reverse_slab_iterator
 
typedef std::reverse_iterator
< slice_iterator
reverse_slice_iterator
 
typedef std::reverse_iterator
< const_slice_iterator
const_reverse_slice_iterator
 
typedef std::reverse_iterator
< iterator
reverse_row_iterator
 
typedef std::reverse_iterator
< const_iterator
const_reverse_row_iterator
 
typedef std::reverse_iterator
< col_iterator
reverse_col_iterator
 
typedef std::reverse_iterator
< const_col_iterator
const_reverse_col_iterator
 
typedef std::reverse_iterator
< slice_range_iterator
reverse_slab_range_iterator
 
typedef std::reverse_iterator
< const_slice_range_iterator
const_reverse_slab_range_iterator
 
typedef std::reverse_iterator
< slice_range_iterator
reverse_slice_range_iterator
 
typedef std::reverse_iterator
< const_slice_range_iterator
const_reverse_slice_range_iterator
 
typedef std::reverse_iterator
< row_range_iterator
reverse_row_range_iterator
 
typedef std::reverse_iterator
< const_row_range_iterator
const_reverse_row_range_iterator
 
typedef std::reverse_iterator
< col_range_iterator
reverse_col_range_iterator
 
typedef std::reverse_iterator
< const_col_range_iterator
const_reverse_col_range_iterator
 
typedef slip::iterator4d_box
< self
iterator4d
 
typedef
slip::const_iterator4d_box
< const_self
const_iterator4d
 
typedef slip::iterator4d_range
< self
iterator4d_range
 
typedef
slip::const_iterator4d_range
< const_self
const_iterator4d_range
 
typedef std::reverse_iterator
< iterator4d
reverse_iterator4d
 
typedef std::reverse_iterator
< const_iterator4d
const_reverse_iterator4d
 
typedef std::reverse_iterator
< iterator4d_range
reverse_iterator4d_range
 
typedef std::reverse_iterator
< const_iterator4d_range
const_reverse_iterator4d_range
 
typedef iterator4d default_iterator
 
typedef const_iterator4d const_default_iterator
 
typedef slip::Range< int > range
 

Public Member Functions

void resize (std::size_t d1, std::size_t d2, std::size_t d3, std::size_t d4, const T &val=T())
 Resizes a Array4d. More...
 
std::string name () const
 Returns the name of the class. More...
 
size_type dim1 () const
 Returns the number of slabs (first dimension size, called time dimension too) in the Array4d. More...
 
size_type slabs () const
 Returns the number of slabs (first dimension size, called time dimension too) in the Array4d. More...
 
size_type dim2 () const
 Returns the number of slices (second dimension size) in the Array4d. More...
 
size_type slices () const
 Returns the number of slices (second dimension size) in the Array4d. More...
 
size_type dim3 () const
 Returns the number of rows (third dimension size) in the Array4d. More...
 
size_type rows () const
 Returns the number of rows (third dimension size) in the Array4d. More...
 
size_type dim4 () const
 Returns the number of columns (fourth dimension size) in the Array4d. More...
 
size_type cols () const
 Returns the number of columns (fourth dimension size) in the Array4d. More...
 
size_type columns () const
 Returns the number of columns (fourth dimension size) in the Array4d. More...
 
size_type size () const
 Returns the number of elements in the Array4d. More...
 
size_type max_size () const
 Returns the maximal size (number of elements) in the Array4d. More...
 
bool empty () const
 Returns true if the Array4d is empty. (Thus size() == 0) More...
 
void swap (Array4d &M)
 Swaps data with another Array4d. More...
 
template<typename T>
 Array4d (const typename Array4d< T >::size_type d1, const typename Array4d< T >::size_type d2, const typename Array4d< T >::size_type d3, const typename Array4d< T >::size_type d4)
 
template<typename T>
 Array4d (const typename Array4d< T >::size_type d1, const typename Array4d< T >::size_type d2, const typename Array4d< T >::size_type d3, const typename Array4d< T >::size_type d4, const T &val)
 
template<typename T>
 Array4d (const typename Array4d< T >::size_type d1, const typename Array4d< T >::size_type d2, const typename Array4d< T >::size_type d3, const typename Array4d< T >::size_type d4, const T *val)
 
Constructors & Destructors
 Array4d ()
 Constructs a Array4d. More...
 
 Array4d (const std::size_t d1, const std::size_t d2, const std::size_t d3, const std::size_t d4)
 Constructs a Array4d. More...
 
 Array4d (const std::size_t d1, const std::size_t d2, const std::size_t d3, const std::size_t d4, const T &val)
 Constructs a Array4d initialized by the scalar value val. More...
 
 Array4d (const std::size_t d1, const std::size_t d2, const std::size_t d3, const std::size_t d4, const T *val)
 Constructs a Array4d initialized by an array val. More...
 
template<typename InputIterator >
 Array4d (const size_type d1, const size_type d2, const size_type d3, const size_type d4, InputIterator first, InputIterator last)
 Contructs a Array4d from a range. More...
 
 Array4d (const Array4d< T > &rhs)
 Constructs a copy of the Array4d rhs. More...
 
 ~Array4d ()
 Destructor of the Array4d. More...
 
One dimensional global iterators
const_iterator begin () const
 Returns a read-only (constant) iterator that points to the first element in the Array4d. Iteration is done in ordinary element order. More...
 
iterator begin ()
 Returns a read/write iterator that points to the first element in the Array4d. Iteration is done in ordinary element order. More...
 
iterator end ()
 Returns a read/write iterator that points one past the last element in the Array4d. Iteration is done in ordinary element order. More...
 
const_iterator end () const
 Returns a read-only (constant) iterator that points one past the last element in the Array4d. Iteration is done in ordinary element order. More...
 
reverse_iterator rbegin ()
 Returns a read/write reverse iterator that points to the last element in the Array4d. Iteration is done in reverse element order. More...
 
const_reverse_iterator rbegin () const
 Returns a read-only (constant) reverse iterator that points to the last element in the Array4d. Iteration is done in reverse element order. More...
 
reverse_iterator rend ()
 Returns a read/write reverse iterator that points to one before the first element in the Array4d. Iteration is done in reverse element order. More...
 
const_reverse_iterator rend () const
 Returns a read-only (constant) reverse iterator that points to one before the first element in the Array4d. Iteration is done in reverse element order. More...
 
One dimensional slab iterators
slab_iterator slab_begin (const size_type slice, const size_type row, const size_type col)
 Returns a read/write iterator that points to the first element of the line (slice,row,col) through the slabs in the Array4d. Iteration is done in ordinary element order (increasing slab number). More...
 
const_slab_iterator slab_begin (const size_type slice, const size_type row, const size_type col) const
 Returns a read-only (constant) iterator that points to the first element of the line (slice,row,col) through the slabs in the Array4d. Iteration is done in ordinary element order (increasing slab number). More...
 
slab_iterator slab_end (const size_type slice, const size_type row, const size_type col)
 Returns a read/write iterator that points to the one past the end element of the line (slice,row,col) through the slabs in the Array4d. Iteration is done in ordinary element order (increasing slab number). More...
 
const_slab_iterator slab_end (const size_type slice, const size_type row, const size_type col) const
 Returns a read-only (constant) iterator that points to the one past the end element of the line (slice,row,col) through the slabs in the Array4d. Iteration is done in ordinary element order (increasing slab number). More...
 
reverse_slab_iterator slab_rbegin (const size_type slice, const size_type row, const size_type col)
 Returns a read/write iterator that points to the last element of the line (slice,row,col) through the slabs in the Array4d. Iteration is done in reverse element order (decreasing slab number). More...
 
const_reverse_slab_iterator slab_rbegin (const size_type slice, const size_type row, const size_type col) const
 Returns a read-only (constant) iterator that points to the last element of the line (slice,row,col) through the slabs in the Array4d. Iteration is done in reverse element order (decreasing slab number). More...
 
reverse_slab_iterator slab_rend (const size_type slice, const size_type row, const size_type col)
 Returns a read/write iterator that points to the one before the first element of the line (slice,row,col) through the slabs in the Array4d. Iteration is done in reverse element order (decreasing slab number). More...
 
const_reverse_slab_iterator slab_rend (const size_type slice, const size_type row, const size_type col) const
 Returns a read (constant) iterator that points to the one before the first element of the line (slice,row,col) through the slabs in the Array4d. Iteration is done in reverse element order (decreasing slab number). More...
 
One dimensional slice iterators
slice_iterator slice_begin (const size_type slab, const size_type row, const size_type col)
 Returns a read/write iterator that points to the first element of the line (slab,row,col) through the slices in the Array4d. Iteration is done in ordinary element order (increasing slice number). More...
 
const_slice_iterator slice_begin (const size_type slab, const size_type row, const size_type col) const
 Returns a read-only (constant) iterator that points to the first element of the line (slab,row,col) through the slices in the Array4d. Iteration is done in ordinary element order (increasing slice number). More...
 
slice_iterator slice_end (const size_type slab, const size_type row, const size_type col)
 Returns a read/write iterator that points to the one past the end element of the line (slab,row,col) through the slices in the Array4d. Iteration is done in ordinary element order (increasing slice number). More...
 
const_slice_iterator slice_end (const size_type slab, const size_type row, const size_type col) const
 Returns a read-only (constant) iterator that points to the one past the end element of the line (slab,row,col) through the slices in the Array4d. Iteration is done in ordinary element order (increasing slice number). More...
 
reverse_slice_iterator slice_rbegin (const size_type slab, const size_type row, const size_type col)
 Returns a read/write iterator that points to the last element of the line (slab,row,col) through the slices in the Array4d. Iteration is done in reverse element order (decreasing slice number). More...
 
const_reverse_slice_iterator slice_rbegin (const size_type slab, const size_type row, const size_type col) const
 Returns a read-only (constant) iterator that points to the last element of the line (slab,row,col) through the slices in the Array4d. Iteration is done in reverse element order (decreasing slice number). More...
 
reverse_slice_iterator slice_rend (const size_type slab, const size_type row, const size_type col)
 Returns a read/write iterator that points to the one before the first element of the line (slab,row,col) through the slices in the Array4d. Iteration is done in reverse element order (decreasing slice number). More...
 
const_reverse_slice_iterator slice_rend (const size_type slab, const size_type row, const size_type col) const
 Returns a read (constant) iterator that points to the one before the first element of the line (slab,row,col) through the slices in the Array4d. Iteration is done in reverse element order (decreasing slice number). More...
 
One dimensional row iterators
row_iterator row_begin (const size_type slab, const size_type slice, const size_type row)
 Returns a read/write iterator that points to the first element of the row row of a given slab slab and a given slice slice in the Array4d. Iteration is done in ordinary element order. More...
 
const_row_iterator row_begin (const size_type slab, const size_type slice, const size_type row) const
 Returns a read_only iterator that points to the first element of the row row of a given slab slab and a given slice slice in the Array4d. Iteration is done in ordinary element order. More...
 
row_iterator row_end (const size_type slab, const size_type slice, const size_type row)
 Returns a read/write iterator that points to the past-the-end element of the row row of a given slab slab and a given slice slice in the Array4d. Iteration is done in ordinary element order. More...
 
const_row_iterator row_end (const size_type slab, const size_type slice, const size_type row) const
 Returns a read_only iterator that points to the past-the-end element of the row row of a given slab slab and a given slice slice in the Array4d. Iteration is done in ordinary element order. More...
 
reverse_row_iterator row_rbegin (const size_type slab, const size_type slice, const size_type row)
 Returns a read/write reverse iterator that points to the last element of the row row of a given slab slab and a given slice slice in the Array4d. Iteration is done in reverse element order. More...
 
const_reverse_row_iterator row_rbegin (const size_type slab, const size_type slice, const size_type row) const
 Returns a read_only reverse iterator that points to the last element of the row row of a given slab slab and a given slice slice in the Array4d. Iteration is done in reverse element order. More...
 
reverse_row_iterator row_rend (const size_type slab, const size_type slice, const size_type row)
 Returns a read/write reverse iterator that points to the first element of the row row of a given slab slab and a given slice slice in the Array4d. Iteration is done in reverse element order. More...
 
const_reverse_row_iterator row_rend (const size_type slab, const size_type slice, const size_type row) const
 Returns a read_only reverse iterator that points to the first element of the row row of a given slab slab and a given slice slice in the Array4d. Iteration is done in reverse element order. More...
 
One dimensional col iterators
col_iterator col_begin (const size_type slab, const size_type slice, const size_type col)
 Returns a read/write iterator that points to the first element of the column column of a given slab slab and a given slice slice in the Array4d. Iteration is done modulo the number of columns. More...
 
const_col_iterator col_begin (const size_type slab, const size_type slice, const size_type col) const
 Returns a read_only iterator that points to the first element of the column column of a given slab slab and a given slice slice in the Array4d. Iteration is done modulo the number of columns. More...
 
col_iterator col_end (const size_type slab, const size_type slice, const size_type col)
 Returns a read/write iterator that points to the past-the-end element of the column column of a given slab slab and a given slice slice in the Array4d. Iteration is done modulo the number of columns. More...
 
const_col_iterator col_end (const size_type slab, const size_type slice, const size_type col) const
 Returns a read_only iterator that points to the past-the-end element of the column column of a given slab slab and a given slice slice in the Array4d. Iteration is done modulo the number of columns. More...
 
reverse_col_iterator col_rbegin (const size_type slab, const size_type slice, const size_type col)
 Returns a read/write reverse iterator that points to the last element of the column column of a given slab slab and a given slice slice in the Array4d. Iteration is done modulo the number of columns. More...
 
const_reverse_col_iterator col_rbegin (const size_type slab, const size_type slice, const size_type col) const
 Returns a read_only reverse iterator that points to the last element of the column column of a given slab slab and a given slice slice in the Array4d. Iteration is done modulo the number of columns. More...
 
reverse_col_iterator col_rend (const size_type slab, const size_type slice, const size_type col)
 Returns a read/write reverse iterator that points to the first element of the column column of a given slab slab and a given slice slice in the Array4d. Iteration is done modulo the number of columns. More...
 
const_reverse_col_iterator col_rend (const size_type slab, const size_type slice, const size_type col) const
 Returns a read_only reverse iterator that points to the first element of the column column of a given slab slab and a given slice slice in the Array4d. Iteration is done modulo the number of columns. More...
 
One dimensional slab range iterators
slab_range_iterator slab_begin (const size_type slice, const size_type row, const size_type col, const slip::Range< int > &range)
 Returns a read/write iterator that points to the first element of the Range range of the of the line (slice,row,col) through the slabs in the Array4d. Iteration is done in ordinary element order according to the Range. More...
 
slab_range_iterator slab_end (const size_type slice, const size_type row, const size_type col, const slip::Range< int > &range)
 Returns a read/write iterator that points one past the end element of the Range range of the of the line (slice,row,col) through the slabs in the Array4d. Iteration is done in ordinary element order according to the Range. More...
 
const_slab_range_iterator slab_begin (const size_type slice, const size_type row, const size_type col, const slip::Range< int > &range) const
 Returns a read only (constant) iterator that points to the first element of the Range range of the of the line (slice,row,col) through the slabs in the Array4d. Iteration is done in ordinary element order according to the Range. More...
 
const_slab_range_iterator slab_end (const size_type slice, const size_type row, const size_type col, const slip::Range< int > &range) const
 Returns a read_only iterator that points one past the last element of the Range range of the of the line (slice,row,col) through the slabs in the Array4d. Iteration is done in ordinary element order according to the Range. More...
 
reverse_slab_range_iterator slab_rbegin (const size_type slice, const size_type row, const size_type col, const slip::Range< int > &range)
 Returns a read/write iterator that points to the last element of the Range range of the of the line (slice,row,col) through the slabs in the Array4d. Iteration is done in the reverse element order according to the Range. More...
 
reverse_slab_range_iterator slab_rend (const size_type slice, const size_type row, const size_type col, const slip::Range< int > &range)
 Returns a read/write iterator that points to the first element of the Range range of the of the line (slice,row,col) through the slabs in the Array4d. Iteration is done in reverse element order according to the Range. More...
 
const_reverse_slab_range_iterator slab_rbegin (const size_type slice, const size_type row, const size_type col, const slip::Range< int > &range) const
 Returns a read only (constant) iterator that points to the last element of the Range range of the of the line (slice,row,col) through the slabs in the Array4d. Iteration is done in reverse element order according to the Range. More...
 
const_reverse_slab_range_iterator slab_rend (const size_type slice, const size_type row, const size_type col, const slip::Range< int > &range) const
 Returns a read_only iterator that points one past the lastto the first element of the Range range of the of the line (slice,row,col) through the slabs in the Array4d. Iteration is done in reverse element order according to the Range. More...
 
One dimensional slice range iterators
slice_range_iterator slice_begin (const size_type slab, const size_type row, const size_type col, const slip::Range< int > &range)
 Returns a read/write iterator that points to the first element of the Range range of the of the line (slab,row,col) through the slices in the Array4d. Iteration is done in ordinary element order according to the Range. More...
 
slice_range_iterator slice_end (const size_type slab, const size_type row, const size_type col, const slip::Range< int > &range)
 Returns a read/write iterator that points one past the end element of the Range range of the of the line (slab,row,col) through the slices in the Array4d. Iteration is done in ordinary element order according to the Range. More...
 
const_slice_range_iterator slice_begin (const size_type slab, const size_type row, const size_type col, const slip::Range< int > &range) const
 Returns a read only (constant) iterator that points to the first element of the Range range of the of the line (slab,row,col) through the slices in the Array4d. Iteration is done in ordinary element order according to the Range. More...
 
const_slice_range_iterator slice_end (const size_type slab, const size_type row, const size_type col, const slip::Range< int > &range) const
 Returns a read_only iterator that points one past the last element of the Range range of the of the line (slab,row,col) through the slices in the Array4d. Iteration is done in ordinary element order according to the Range. More...
 
reverse_slice_range_iterator slice_rbegin (const size_type slab, const size_type row, const size_type col, const slip::Range< int > &range)
 Returns a read/write iterator that points to the last element of the Range range of the of the line (slab,row,col) through the slices in the Array4d. Iteration is done in the reverse element order according to the Range. More...
 
reverse_slice_range_iterator slice_rend (const size_type slab, const size_type row, const size_type col, const slip::Range< int > &range)
 Returns a read/write iterator that points to the first element of the Range range of the of the line (slab,row,col) through the slices in the Array4d. Iteration is done in reverse element order according to the Range. More...
 
const_reverse_slice_range_iterator slice_rbegin (const size_type slab, const size_type row, const size_type col, const slip::Range< int > &range) const
 Returns a read only (constant) iterator that points to the last element of the Range range of the of the line (slab,row,col) through the slices in the Array4d. Iteration is done in reverse element order according to the Range. More...
 
const_reverse_slice_range_iterator slice_rend (const size_type slab, const size_type row, const size_type col, const slip::Range< int > &range) const
 Returns a read_only iterator that points one past the lastto the first element of the Range range of the of the line (slab,row,col) through the slices in the Array4d. Iteration is done in reverse element order according to the Range. More...
 
One dimensional row range iterators
row_range_iterator row_begin (const size_type slab, const size_type slice, const size_type row, const slip::Range< int > &range)
 Returns a read/write iterator that points to the first element of the Range range of the row row in the slab slab and the slice slice in the Array4d. Iteration is done in ordinary element order according to the Range. More...
 
row_range_iterator row_end (const size_type slab, const size_type slice, const size_type row, const slip::Range< int > &range)
 Returns a read/write iterator that points one past the end element of the Range range of the row row in the slab slab and the slice slice in the Array4d. Iteration is done in ordinary element order according to the Range. More...
 
const_row_range_iterator row_begin (const size_type slab, const size_type slice, const size_type row, const slip::Range< int > &range) const
 Returns a read-only iterator that points to the first element of the Range range of the row row in the slab slab and the slice slice in the Array4d. Iteration is done in ordinary element order according to the Range. More...
 
const_row_range_iterator row_end (const size_type slab, const size_type slice, const size_type row, const slip::Range< int > &range) const
 Returns a read_only iterator that points one past the last element of the Range range of the row row in the slab slab and the slice slice in the Array4d. Iteration is done in ordinary element order according to the Range. More...
 
reverse_row_range_iterator row_rbegin (const size_type slab, const size_type slice, const size_type row, const slip::Range< int > &range)
 Returns a read-write iterator that points to the last element of the Range range of the row row in the slab slab and the slice slice in the Array4d. Iteration is done in the reverse element order according to the Range. More...
 
reverse_row_range_iterator row_rend (const size_type slab, const size_type slice, const size_type row, const slip::Range< int > &range)
 Returns a read-write iterator that points one before the first element of the Range range of the row row in the slab slab and the slice slice in the Array4d. Iteration is done in the reverse element order according to the Range. More...
 
const_reverse_row_range_iterator row_rbegin (const size_type slab, const size_type slice, const size_type row, const slip::Range< int > &range) const
 Returns a read-only iterator that points to the last element of the Range range of the row row in the slab slab and the slice slice in the Array4d. Iteration is done in the reverse element order according to the Range. More...
 
const_reverse_row_range_iterator row_rend (const size_type slab, const size_type slice, const size_type row, const slip::Range< int > &range) const
 Returns a read-only iterator that points one before the first element of the Range range of the row row in the slab slab and the slice slice in the Array4d. Iteration is done in the reverse element order according to the Range. More...
 
One dimensional col range iterators
col_range_iterator col_begin (const size_type slab, const size_type slice, const size_type col, const slip::Range< int > &range)
 Returns a read-write iterator that points to the first element of the Range range of the col col in the slab slab and the slice slice in the Array4d. Iteration is done in ordinary element order according to the Range. More...
 
col_range_iterator col_end (const size_type slab, const size_type slice, const size_type col, const slip::Range< int > &range)
 Returns a read-write iterator that points to the past the end element of the Range range of the col col in the slab slab and the slice slice in the Array4d. Iteration is done in ordinary element order according to the Range. More...
 
const_col_range_iterator col_begin (const size_type slab, const size_type slice, const size_type col, const slip::Range< int > &range) const
 Returns a read-only iterator that points to the first element of the Range range of the col col in the slab slab and the slice slice in the Array4d. Iteration is done in ordinary element order according to the Range. More...
 
const_col_range_iterator col_end (const size_type slab, const size_type slice, const size_type col, const slip::Range< int > &range) const
 Returns a read-only iterator that points to the past the end element of the Range range of the col col in the slab slab and the slice slice in the Array4d. More...
 
reverse_col_range_iterator col_rbegin (const size_type slab, const size_type slice, const size_type col, const slip::Range< int > &range)
 Returns a read-write iterator that points to the last element of the Range range of the col of a slice col in the slab slab and the slice slice in the Array4d. Iteration is done in the reverse element order according to the Range. More...
 
reverse_col_range_iterator col_rend (const size_type slab, const size_type slice, const size_type col, const slip::Range< int > &range)
 Returns a read-write iterator that points to one before the first element of the Range range of the col of a slice col in the slab slab and the slice slice in the Array4d. Iteration is done in the reverse element order according to the Range. More...
 
const_reverse_col_range_iterator col_rbegin (const size_type slab, const size_type slice, const size_type col, const slip::Range< int > &range) const
 Returns a read_only iterator that points to the last element of the Range & range of the col of a slice col in the slab slab and the slice slice in the Array4d. Iteration is done in the reverse element order according to the Range. More...
 
const_reverse_col_range_iterator col_rend (const size_type slab, const size_type slice, const size_type col, const slip::Range< int > &range) const
 Returns a read-only iterator that points to the first element of the Range range of the col of a slice col in the slab slab and the slice slice in the Array4d. Iteration is done in the reverse element order according to the Range. More...
 
four dimensional iterators : Global iterators
iterator4d first_front_upper_left ()
 Returns a read/write iterator4d that points to the first element of the Array4d. It points to the first front upper left element of the Array4d. More...
 
iterator4d last_back_bottom_right ()
 Returns a read/write iterator4d that points to the past the end element of the Array4d. It points to past the end element of the last back bottom right element of the Array4d. More...
 
const_iterator4d first_front_upper_left () const
 Returns a read-only iterator4d that points to the first element of the Array4d. It points to the fist front upper left element of the Array4d. More...
 
const_iterator4d last_back_bottom_right () const
 Returns a read-only iterator4d that points to the past the end element of the Array4d. It points to past the end element of the last back bottom right element of the Array4d. More...
 
reverse_iterator4d rfirst_front_upper_left ()
 Returns a read/write reverse iterator4d. It points to the last back bottom right element of the Array4d. Iteration is done within the Array4d in the reverse order. More...
 
reverse_iterator4d rlast_back_bottom_right ()
 Returns a read/write reverse iterator4d. It points to past the first front upper left element of the Array4d. Iteration is done in the reverse order. More...
 
const_reverse_iterator4d rfirst_front_upper_left () const
 Returns a read only reverse iterator4d that points. It points to the last back bottom right element of the Array4d. Iteration is done within the Array4d in the reverse order. More...
 
const_reverse_iterator4d rlast_back_bottom_right () const
 Returns a read only reverse iterator4d. It points to past the first front upper left element of the Array4d. Iteration is done in the reverse order. More...
 
four dimensional iterators : Box iterators
iterator4d first_front_upper_left (const Box4d< int > &box)
 Returns a read/write iterator4d that points to the first element of the Array4d. It points to the first front upper left element of the Box4d associated to the Array4d. More...
 
iterator4d last_back_bottom_right (const Box4d< int > &box)
 Returns a read/write iterator4d that points to the past the end element of the Array4d. It points to past the end element of the last back bottom right element of the Box4d associated to the Array4d. More...
 
const_iterator4d first_front_upper_left (const Box4d< int > &box) const
 Returns a read only iterator4d that points to the first element of the Array4d. It points to the front upper left element of the Box4d associated to the Array4d. More...
 
const_iterator4d last_back_bottom_right (const Box4d< int > &box) const
 Returns a read only iterator4d that points to the past the end element of the Array4d. It points to past the end element of the back bottom right element of the Box4d associated to the Array4d. More...
 
reverse_iterator4d rfirst_front_upper_left (const Box4d< int > &box)
 Returns a read/write reverse iterator4d. It points to the back bottom right element of the Box4d associated to the Array4d. Iteration is done in the reverse order. More...
 
reverse_iterator4d rlast_back_bottom_right (const Box4d< int > &box)
 Returns a read/write reverse iterator4d. It points to one before the front upper left element of the Box4d box associated to the Array4d. More...
 
const_reverse_iterator4d rfirst_front_upper_left (const Box4d< int > &box) const
 Returns a read only reverse iterator4d. It points to the back bottom right element of the Box4d box associated to the Array4d. Iteration is done in the reverse order. More...
 
const_reverse_iterator4d rlast_back_bottom_right (const Box4d< int > &box) const
 Returns a read-only reverse iterator4d. It points to one before the front element of the bottom right element of the Box4d box associated to the Array4d. More...
 
four dimensional iterators : Range iterators
iterator4d_range first_front_upper_left (const range &slab_range, const range &slice_range, const range &row_range, const range &col_range)
 Returns a read/write iterator4d_range that points to the first front upper left element of the ranges slab_range, slice_range, row_range and col_range associated to the Array4d. More...
 
iterator4d_range last_back_bottom_right (const range &slab_range, const range &slice_range, const range &row_range, const range &col_range)
 Returns a read/write iterator4d_range that points to the past the end last back bottom right element of the ranges slab_range, slice_range, row_range and col_range associated to the Array4d. More...
 
const_iterator4d_range first_front_upper_left (const range &slab_range, const range &slice_range, const range &row_range, const range &col_range) const
 Returns a read-only iterator4d_range that points to the to the first front upper left element of the ranges slab_range, slice_range, row_range and col_range associated to the Array4d. More...
 
const_iterator4d_range last_back_bottom_right (const range &slab_range, const range &slice_range, const range &row_range, const range &col_range) const
 Returns a read-only iterator4d_range that points to the past the end last back bottom right element of the ranges slab_range, slice_range, row_range and col_range associated to the Array4d. More...
 
reverse_iterator4d_range rfirst_front_upper_left (const range &slab_range, const range &slice_range, const range &row_range, const range &col_range)
 Returns a read/write reverse_iterator4d_range that points to the past the last back bottom right element of the ranges slab_range, slice_range, row_range and col_range associated to the Array4d. Iteration is done in the reverse order. More...
 
reverse_iterator4d_range rlast_back_bottom_right (const range &slab_range, const range &slice_range, const range &row_range, const range &col_range)
 Returns a read/write reverse_iterator4d_range that points to one before the first front upper left element of the ranges slab_range, slice_range, row_range and col_range associated to the Array4d. Iteration is done in the reverse order. More...
 
const_reverse_iterator4d_range rfirst_front_upper_left (const range &slab_range, const range &slice_range, const range &row_range, const range &col_range) const
 Returns a read-only reverse_iterator4d_range that points to the past the last back bottom right element of the ranges slab_range, slice_range, row_range and col_range associated to the Array4d. Iteration is done in the reverse order. More...
 
const_reverse_iterator4d_range rlast_back_bottom_right (const range &slab_range, const range &slice_range, const range &row_range, const range &col_range) const
 Returns a read-only reverse_iterator4d_range that points to one before the first front upper left element of the ranges slab_range, slice_range, row_range and col_range associated to the Array4d. Iteration is done in the reverse order. More...
 
Assignment operators and methods
selfoperator= (const Array4d< T > &rhs)
 Assign a Array4d. More...
 
selfoperator= (const T &value)
 Assign all the elments of the Array4d by value. More...
 
void fill (const T &value)
 Fills the container range [begin(),begin()+size()) with copies of value. More...
 
void fill (const T *value)
 Fills the container range [begin(),begin()+size()) with a copy of the value array. More...
 
template<typename InputIterator >
void fill (InputIterator first, InputIterator last)
 Fills the container range [begin(),begin()+size()) with a copy of the range [first,last) More...
 
Element access operators
T *** operator[] (const size_type l)
 
const T **const * operator[] (const size_type l) const
 
reference operator() (const size_type l, const size_type k, const size_type i, const size_type j)
 Subscript access to the data contained in the Array4d. More...
 
const_reference operator() (const size_type l, const size_type k, const size_type i, const size_type j) const
 Subscript access to the data contained in the Array4d. More...
 

Static Public Attributes

static const std::size_t DIM = 4
 

Friends

class boost::serialization::access
 
i/o operators
std::ostream & operator<< (std::ostream &out, const self &a)
 Write the Array4d to the ouput stream. More...
 
Comparison operators
bool operator== (const Array4d< T > &x, const Array4d< T > &y)
 Array4d equality comparison More...
 
bool operator!= (const Array4d< T > &x, const Array4d< T > &y)
 Array4d inequality comparison More...
 
bool operator< (const Array4d< T > &x, const Array4d< T > &y)
 Less than comparison operator (Array4d ordering relation) More...
 
bool operator> (const Array4d< T > &x, const Array4d< T > &y)
 More than comparison operator. More...
 
bool operator<= (const Array4d< T > &x, const Array4d< T > &y)
 Less than equal comparison operator. More...
 
bool operator>= (const Array4d< T > &x, const Array4d< T > &y)
 More than equal comparison operator. More...
 

Detailed Description

template<typename T>
class slip::Array4d< T >

This is a four-dimensional dynamic and generic container. This container statisfies the BidirectionnalContainer concepts of the STL. It is also an 4d extension of the RandomAccessContainer concept. That is to say the bracket element access is replaced by the quadruple bracket element access.

Version
Fluex 1.0
Date
2013/07/04
2014/03/13
Since
1.4.0
Author
Denis Arrivault <denis.arrivault_AT_inria.fr>
Parameters
TType of the elements in the Array4d.
Axis conventions:
iterator4d_conventions.jpg
axis and notation conventions

Definition at line 105 of file Array4d.hpp.

Member Typedef Documentation

template<typename T>
typedef slip::stride_iterator<pointer> slip::Array4d< T >::col_iterator

Definition at line 190 of file Array4d.hpp.

Definition at line 199 of file Array4d.hpp.

Definition at line 191 of file Array4d.hpp.

Definition at line 200 of file Array4d.hpp.

template<typename T>
typedef const_iterator4d slip::Array4d< T >::const_default_iterator

Definition at line 232 of file Array4d.hpp.

template<typename T>
typedef value_type const* slip::Array4d< T >::const_iterator

Definition at line 178 of file Array4d.hpp.

Definition at line 221 of file Array4d.hpp.

Definition at line 223 of file Array4d.hpp.

template<typename T>
typedef value_type const* slip::Array4d< T >::const_pointer

Definition at line 172 of file Array4d.hpp.

template<typename T>
typedef value_type const& slip::Array4d< T >::const_reference

Definition at line 169 of file Array4d.hpp.

template<typename T>
typedef std::reverse_iterator<const_col_iterator> slip::Array4d< T >::const_reverse_col_iterator

Definition at line 209 of file Array4d.hpp.

template<typename T>
typedef std::reverse_iterator<const_col_range_iterator> slip::Array4d< T >::const_reverse_col_range_iterator

Definition at line 217 of file Array4d.hpp.

template<typename T>
typedef std::reverse_iterator<const_iterator> slip::Array4d< T >::const_reverse_iterator

Definition at line 181 of file Array4d.hpp.

template<typename T>
typedef std::reverse_iterator<const_iterator4d> slip::Array4d< T >::const_reverse_iterator4d

Definition at line 226 of file Array4d.hpp.

template<typename T>
typedef std::reverse_iterator<const_iterator4d_range> slip::Array4d< T >::const_reverse_iterator4d_range

Definition at line 228 of file Array4d.hpp.

template<typename T>
typedef std::reverse_iterator<const_iterator> slip::Array4d< T >::const_reverse_row_iterator

Definition at line 207 of file Array4d.hpp.

template<typename T>
typedef std::reverse_iterator<const_row_range_iterator> slip::Array4d< T >::const_reverse_row_range_iterator

Definition at line 215 of file Array4d.hpp.

template<typename T>
typedef std::reverse_iterator<const_slab_iterator> slip::Array4d< T >::const_reverse_slab_iterator

Definition at line 203 of file Array4d.hpp.

template<typename T>
typedef std::reverse_iterator<const_slice_range_iterator> slip::Array4d< T >::const_reverse_slab_range_iterator

Definition at line 211 of file Array4d.hpp.

template<typename T>
typedef std::reverse_iterator<const_slice_iterator> slip::Array4d< T >::const_reverse_slice_iterator

Definition at line 205 of file Array4d.hpp.

template<typename T>
typedef std::reverse_iterator<const_slice_range_iterator> slip::Array4d< T >::const_reverse_slice_range_iterator

Definition at line 213 of file Array4d.hpp.

template<typename T>
typedef const_pointer slip::Array4d< T >::const_row_iterator

Definition at line 189 of file Array4d.hpp.

Definition at line 198 of file Array4d.hpp.

template<typename T>
typedef const Array4d<T> slip::Array4d< T >::const_self

Definition at line 166 of file Array4d.hpp.

Definition at line 185 of file Array4d.hpp.

Definition at line 194 of file Array4d.hpp.

Definition at line 187 of file Array4d.hpp.

Definition at line 196 of file Array4d.hpp.

template<typename T>
typedef iterator4d slip::Array4d< T >::default_iterator

Definition at line 231 of file Array4d.hpp.

template<typename T>
typedef ptrdiff_t slip::Array4d< T >::difference_type

Definition at line 174 of file Array4d.hpp.

template<typename T>
typedef value_type* slip::Array4d< T >::iterator

Definition at line 177 of file Array4d.hpp.

template<typename T>
typedef slip::iterator4d_box<self> slip::Array4d< T >::iterator4d

Definition at line 220 of file Array4d.hpp.

template<typename T>
typedef slip::iterator4d_range<self> slip::Array4d< T >::iterator4d_range

Definition at line 222 of file Array4d.hpp.

template<typename T>
typedef value_type* slip::Array4d< T >::pointer

Definition at line 171 of file Array4d.hpp.

template<typename T>
typedef slip::Range<int> slip::Array4d< T >::range

Definition at line 235 of file Array4d.hpp.

template<typename T>
typedef value_type& slip::Array4d< T >::reference

Definition at line 168 of file Array4d.hpp.

template<typename T>
typedef std::reverse_iterator<col_iterator> slip::Array4d< T >::reverse_col_iterator

Definition at line 208 of file Array4d.hpp.

template<typename T>
typedef std::reverse_iterator<col_range_iterator> slip::Array4d< T >::reverse_col_range_iterator

Definition at line 216 of file Array4d.hpp.

template<typename T>
typedef std::reverse_iterator<iterator> slip::Array4d< T >::reverse_iterator

Definition at line 180 of file Array4d.hpp.

template<typename T>
typedef std::reverse_iterator<iterator4d> slip::Array4d< T >::reverse_iterator4d

Definition at line 225 of file Array4d.hpp.

template<typename T>
typedef std::reverse_iterator<iterator4d_range> slip::Array4d< T >::reverse_iterator4d_range

Definition at line 227 of file Array4d.hpp.

template<typename T>
typedef std::reverse_iterator<iterator> slip::Array4d< T >::reverse_row_iterator

Definition at line 206 of file Array4d.hpp.

template<typename T>
typedef std::reverse_iterator<row_range_iterator> slip::Array4d< T >::reverse_row_range_iterator

Definition at line 214 of file Array4d.hpp.

template<typename T>
typedef std::reverse_iterator<slab_iterator> slip::Array4d< T >::reverse_slab_iterator

Definition at line 202 of file Array4d.hpp.

template<typename T>
typedef std::reverse_iterator<slice_range_iterator> slip::Array4d< T >::reverse_slab_range_iterator

Definition at line 210 of file Array4d.hpp.

template<typename T>
typedef std::reverse_iterator<slice_iterator> slip::Array4d< T >::reverse_slice_iterator

Definition at line 204 of file Array4d.hpp.

template<typename T>
typedef std::reverse_iterator<slice_range_iterator> slip::Array4d< T >::reverse_slice_range_iterator

Definition at line 212 of file Array4d.hpp.

template<typename T>
typedef pointer slip::Array4d< T >::row_iterator

Definition at line 188 of file Array4d.hpp.

template<typename T>
typedef slip::stride_iterator<pointer> slip::Array4d< T >::row_range_iterator

Definition at line 197 of file Array4d.hpp.

template<typename T>
typedef Array4d<T> slip::Array4d< T >::self

Definition at line 165 of file Array4d.hpp.

template<typename T>
typedef std::size_t slip::Array4d< T >::size_type

Definition at line 175 of file Array4d.hpp.

template<typename T>
typedef slip::stride_iterator<pointer> slip::Array4d< T >::slab_iterator

Definition at line 184 of file Array4d.hpp.

Definition at line 193 of file Array4d.hpp.

template<typename T>
typedef slip::stride_iterator<pointer> slip::Array4d< T >::slice_iterator

Definition at line 186 of file Array4d.hpp.

Definition at line 195 of file Array4d.hpp.

template<typename T>
typedef T slip::Array4d< T >::value_type

Definition at line 164 of file Array4d.hpp.

Constructor & Destructor Documentation

template<typename T >
slip::Array4d< T >::Array4d ( )
inline

Constructs a Array4d.

Definition at line 3251 of file Array4d.hpp.

template<typename T>
slip::Array4d< T >::Array4d ( const std::size_t  d1,
const std::size_t  d2,
const std::size_t  d3,
const std::size_t  d4 
)

Constructs a Array4d.

Parameters
d1first dimension of the Array4d
d2second dimension of the Array4d
d3third dimension of the Array4d
d4fourth dimension of the Array4d
The Array4d is initialized by the default value of T.
template<typename T>
slip::Array4d< T >::Array4d ( const std::size_t  d1,
const std::size_t  d2,
const std::size_t  d3,
const std::size_t  d4,
const T &  val 
)

Constructs a Array4d initialized by the scalar value val.

Parameters
d1first dimension of the Array4d
d2second dimension of the Array4d
d3third dimension of the Array4d
d4fourth dimension of the Array4d
valinitialization value of the elements
template<typename T>
slip::Array4d< T >::Array4d ( const std::size_t  d1,
const std::size_t  d2,
const std::size_t  d3,
const std::size_t  d4,
const T *  val 
)

Constructs a Array4d initialized by an array val.

Parameters
d1first dimension of the Array4d
d2second dimension of the Array4d
d3third dimension of the Array4d
d4fourth dimension of the Array4d
valinitialization array value of the elements
template<typename T>
template<typename InputIterator >
slip::Array4d< T >::Array4d ( const size_type  d1,
const size_type  d2,
const size_type  d3,
const size_type  d4,
InputIterator  first,
InputIterator  last 
)
inline

Contructs a Array4d from a range.

Parameters
d1first dimension of the Array4d
d2second dimension of the Array4d
d3third dimension of the Array4d
d4fourth dimension of the Array4d
firstAn input iterator.
lastAn input iterator.
Date
2014/03/13 Create a Array4d consisting of copies of the elements from [first,last).

Definition at line 303 of file Array4d.hpp.

template<typename T>
slip::Array4d< T >::Array4d ( const Array4d< T > &  rhs)
inline

Constructs a copy of the Array4d rhs.

Definition at line 3296 of file Array4d.hpp.

template<typename T >
slip::Array4d< T >::~Array4d ( )
inline

Destructor of the Array4d.

Definition at line 3308 of file Array4d.hpp.

template<typename T>
template<typename T>
slip::Array4d< T >::Array4d ( const typename Array4d< T >::size_type  d1,
const typename Array4d< T >::size_type  d2,
const typename Array4d< T >::size_type  d3,
const typename Array4d< T >::size_type  d4 
)
inline

Definition at line 3258 of file Array4d.hpp.

template<typename T>
template<typename T>
slip::Array4d< T >::Array4d ( const typename Array4d< T >::size_type  d1,
const typename Array4d< T >::size_type  d2,
const typename Array4d< T >::size_type  d3,
const typename Array4d< T >::size_type  d4,
const T &  val 
)
inline

Definition at line 3270 of file Array4d.hpp.

template<typename T>
template<typename T>
slip::Array4d< T >::Array4d ( const typename Array4d< T >::size_type  d1,
const typename Array4d< T >::size_type  d2,
const typename Array4d< T >::size_type  d3,
const typename Array4d< T >::size_type  d4,
const T *  val 
)
inline

Definition at line 3283 of file Array4d.hpp.

Member Function Documentation

template<typename T >
Array4d< T >::const_iterator slip::Array4d< T >::begin ( ) const
inline

Returns a read-only (constant) iterator that points to the first element in the Array4d. Iteration is done in ordinary element order.

Returns
const begin iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Example:
slip::Array4d<double> const A1(10,9,5,2);
slip::Array4d<double> const A2(10,9,5,2);
slip::Array4d<double> S(10,9,5,2);
//copy the sum of A1 and A2 in S
std::transform(A1.begin(),A1.end(),
A2.begin(),S.begin(),
std::plus<double>());

Definition at line 3390 of file Array4d.hpp.

template<typename T >
Array4d< T >::iterator slip::Array4d< T >::begin ( )
inline

Returns a read/write iterator that points to the first element in the Array4d. Iteration is done in ordinary element order.

Returns
begin iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Example:
slip::Array4d<double> A1(10,9,5,2);
slip::Array4d<double> A2(10,9,5,2);
slip::Array4d<double> S(10,9,5,2);
//copy the sum of A1 and A2 in S
std::transform(A1.begin(),A1.end(),
A2.begin(),S.begin(),
std::plus<double>());

Definition at line 3404 of file Array4d.hpp.

template<typename T>
col_iterator slip::Array4d< T >::col_begin ( const size_type  slab,
const size_type  slice,
const size_type  col 
)

Returns a read/write iterator that points to the first element of the column column of a given slab slab and a given slice slice in the Array4d. Iteration is done modulo the number of columns.

Parameters
slabThe index of the slab.
sliceThe index of the slice.
colThe index of the column
Returns
begin col_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Note
The row and col iterators iterate in the rows and columns respectively. There are different from slab and slice iterators that cross the slabs and slices respectively.
template<typename T>
const_col_iterator slip::Array4d< T >::col_begin ( const size_type  slab,
const size_type  slice,
const size_type  col 
) const

Returns a read_only iterator that points to the first element of the column column of a given slab slab and a given slice slice in the Array4d. Iteration is done modulo the number of columns.

Parameters
slabThe index of the slab.
sliceThe index of the slice.
colThe index of the column
Returns
begin const_col_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Note
The row and col iterators iterate in the rows and columns respectively. There are different from slab and slice iterators that cross the slabs and slices respectively.
template<typename T>
col_range_iterator slip::Array4d< T >::col_begin ( const size_type  slab,
const size_type  slice,
const size_type  col,
const slip::Range< int > &  range 
)

Returns a read-write iterator that points to the first element of the Range range of the col col in the slab slab and the slice slice in the Array4d. Iteration is done in ordinary element order according to the Range.

Parameters
slabslab coordinate of the line
sliceThe index of the slice.
colThe index of the column to iterate.
rangeRange of the column to iterate
Returns
begin col_range_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Precondition
col must be compatible with the range of the Array4d.
The range must be inside the whole range of the Array4d.
Example:
slip::Array4d<double> A1(8,8,8,8);
slip::Array4d<double> A2(4,8,5,8);
slip::Range<int> range(0,A1.dim4()-1,2);
//copy the the elements of the column 0 in the slab 0 and the slice 0 of A1 iterated according to the
//range in the column 1 in the slab 1 and the slice 1 of A2
std::copy(A1.col_begin(0,0,0,range),A1.col_end(0,0,0,range),A2.col_begin(1,1,1));
template<typename T>
const_col_range_iterator slip::Array4d< T >::col_begin ( const size_type  slab,
const size_type  slice,
const size_type  col,
const slip::Range< int > &  range 
) const

Returns a read-only iterator that points to the first element of the Range range of the col col in the slab slab and the slice slice in the Array4d. Iteration is done in ordinary element order according to the Range.

Parameters
slabslab coordinate of the line
sliceThe index of the slice.
colThe index of the column to iterate.
rangeRange of the column to iterate.
Returns
begin const_col_range_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Precondition
col must be compatible with the range of the Array4d.
The range must be inside the whole range of the Array4d.
Example:
slip::Array4d<double> A1(8,8,8,8);
slip::Array4d<double> A2(4,8,5,8);
slip::Range<int> range(0,A1.dim4()-1,2);
//copy the the elements of the column 0 in the slab 0 and the slice 0 of A1 iterated according to the
//range in the column 1 in the slab 1 and the slice 1 of A2
std::copy(A1.col_begin(0,0,0,range),A1.col_end(0,0,0,range),A2.col_begin(1,1,1));
template<typename T>
col_iterator slip::Array4d< T >::col_end ( const size_type  slab,
const size_type  slice,
const size_type  col 
)

Returns a read/write iterator that points to the past-the-end element of the column column of a given slab slab and a given slice slice in the Array4d. Iteration is done modulo the number of columns.

Parameters
slabThe index of the slab.
sliceThe index of the slice.
colThe index of the column
Returns
end col_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Note
The row and col iterators iterate in the rows and columns respectively. There are different from slab and slice iterators that cross the slabs and slices respectively.
template<typename T>
const_col_iterator slip::Array4d< T >::col_end ( const size_type  slab,
const size_type  slice,
const size_type  col 
) const

Returns a read_only iterator that points to the past-the-end element of the column column of a given slab slab and a given slice slice in the Array4d. Iteration is done modulo the number of columns.

Parameters
slabThe index of the slab.
sliceThe index of the slice.
colThe index of the column
Returns
end const_col_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Note
The row and col iterators iterate in the rows and columns respectively. There are different from slab and slice iterators that cross the slabs and slices respectively.
template<typename T>
col_range_iterator slip::Array4d< T >::col_end ( const size_type  slab,
const size_type  slice,
const size_type  col,
const slip::Range< int > &  range 
)

Returns a read-write iterator that points to the past the end element of the Range range of the col col in the slab slab and the slice slice in the Array4d. Iteration is done in ordinary element order according to the Range.

Parameters
slabslab coordinate of the line
sliceThe index of the slice.
colThe index of the column to iterate.
rangeRange of the column to iterate.
Returns
begin col_range_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Precondition
col must be compatible with the range of the Array4d.
The range must be inside the whole range of the Array4d.
Example:
slip::Array4d<double> A1(8,8,8,8);
slip::Array4d<double> A2(4,8,5,8);
slip::Range<int> range(0,A1.dim4()-1,2);
//copy the the elements of the column 0 in the slab 0 and the slice 0 of A1 iterated according to the
//range in the column 1 in the slab 1 and the slice 1 of A2
std::copy(A1.col_begin(0,0,0,range),A1.col_end(0,0,0,range),A2.col_begin(1,1,1));
template<typename T>
const_col_range_iterator slip::Array4d< T >::col_end ( const size_type  slab,
const size_type  slice,
const size_type  col,
const slip::Range< int > &  range 
) const

Returns a read-only iterator that points to the past the end element of the Range range of the col col in the slab slab and the slice slice in the Array4d.

Parameters
slabslab coordinate of the line Iteration is done in ordinary element order according to the Range.
sliceThe index of the slice.
colThe index of the column to iterate.
rangeRange of the column to iterate
Returns
begin const_col_range_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Precondition
col must be compatible with the range of the Array4d.
The range must be inside the whole range of the Array4d.
Example:
slip::Array4d<double> A1(8,8,8,8);
slip::Array4d<double> A2(4,8,5,8);
slip::Range<int> range(0,A1.dim4()-1,2);
//copy the the elements of the column 0 in the slab 0 and the slice 0 of A1 iterated according to the
//range in the column 1 in the slab 1 and the slice 1 of A2
std::copy(A1.col_begin(0,0,0,range),A1.col_end(0,0,0,range),A2.col_begin(1,1,1));
template<typename T>
reverse_col_iterator slip::Array4d< T >::col_rbegin ( const size_type  slab,
const size_type  slice,
const size_type  col 
)

Returns a read/write reverse iterator that points to the last element of the column column of a given slab slab and a given slice slice in the Array4d. Iteration is done modulo the number of columns.

Parameters
slabThe index of the slab.
sliceThe index of the slice.
colThe index of the column
Returns
begin reverse_col_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Note
The row and col iterators iterate in the rows and columns respectively. There are different from slab and slice iterators that cross the slabs and slices respectively.
template<typename T>
const_reverse_col_iterator slip::Array4d< T >::col_rbegin ( const size_type  slab,
const size_type  slice,
const size_type  col 
) const

Returns a read_only reverse iterator that points to the last element of the column column of a given slab slab and a given slice slice in the Array4d. Iteration is done modulo the number of columns.

Parameters
slabThe index of the slab.
sliceThe index of the slice.
colThe index of the column
Returns
begin const_reverse_col_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Note
The row and col iterators iterate in the rows and columns respectively. There are different from slab and slice iterators that cross the slabs and slices respectively.
template<typename T>
reverse_col_range_iterator slip::Array4d< T >::col_rbegin ( const size_type  slab,
const size_type  slice,
const size_type  col,
const slip::Range< int > &  range 
)

Returns a read-write iterator that points to the last element of the Range range of the col of a slice col in the slab slab and the slice slice in the Array4d. Iteration is done in the reverse element order according to the Range.

Parameters
slabslab coordinate of the line
sliceThe index of the slice.
colThe index of the column to iterate.
rangeRange of the column to iterate.
Returns
begin reverse_col_range_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Precondition
col must be compatible with the range of the Array4d.
The range must be inside the whole range of the Array4d.
Example:
slip::Range<int> range(0,A1.dim4()-1,2);
//copy the the elements of the column 0 in the slab 0 and the slice 0 of A1 iterated
//in reverse order according to the range in the column 1 in the slab 1 and the slice 1 of A2
std::copy(A1.col_rbegin(0,0,0,range),A1.col_rend(0,0,0,range),A2.col_begin(1,1,1));
template<typename T>
const_reverse_col_range_iterator slip::Array4d< T >::col_rbegin ( const size_type  slab,
const size_type  slice,
const size_type  col,
const slip::Range< int > &  range 
) const

Returns a read_only iterator that points to the last element of the Range & range of the col of a slice col in the slab slab and the slice slice in the Array4d. Iteration is done in the reverse element order according to the Range.

Parameters
slabslab coordinate of the line
sliceThe index of the slice.
colThe index of the column to iterate.
rangeRange of the column to iterate.
Returns
begin const_reverse_col_range_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Precondition
col must be compatible with the range of the Array4d.
The range must be inside the whole range of the Array4d.
Example:
slip::Range<int> range(0,A1.dim4()-1,2);
//copy the the elements of the column 0 in the slab 0 and the slice 0 of A1 iterated
//in reverse order according to the range in the column 1 in the slab 1 and the slice 1 of A2
std::copy(A1.col_rbegin(0,0,0,range),A1.col_rend(0,0,0,range),A2.col_begin(1,1,1));
template<typename T>
reverse_col_iterator slip::Array4d< T >::col_rend ( const size_type  slab,
const size_type  slice,
const size_type  col 
)

Returns a read/write reverse iterator that points to the first element of the column column of a given slab slab and a given slice slice in the Array4d. Iteration is done modulo the number of columns.

Parameters
slabThe index of the slab.
sliceThe index of the slice.
colThe index of the column
Returns
end reverse_col_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Note
The row and col iterators iterate in the rows and columns respectively. There are different from slab and slice iterators that cross the slabs and slices respectively.
template<typename T>
const_reverse_col_iterator slip::Array4d< T >::col_rend ( const size_type  slab,
const size_type  slice,
const size_type  col 
) const

Returns a read_only reverse iterator that points to the first element of the column column of a given slab slab and a given slice slice in the Array4d. Iteration is done modulo the number of columns.

Parameters
slabThe index of the slab.
sliceThe index of the slice.
colThe index of the column
Returns
end const_reverse_col_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Note
The row and col iterators iterate in the rows and columns respectively. There are different from slab and slice iterators that cross the slabs and slices respectively.
template<typename T>
reverse_col_range_iterator slip::Array4d< T >::col_rend ( const size_type  slab,
const size_type  slice,
const size_type  col,
const slip::Range< int > &  range 
)

Returns a read-write iterator that points to one before the first element of the Range range of the col of a slice col in the slab slab and the slice slice in the Array4d. Iteration is done in the reverse element order according to the Range.

Parameters
slabslab coordinate of the line
sliceThe index of the slice.
colThe index of the column to iterate.
rangeRange of the column to iterate.
Returns
reverse_col_range_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Precondition
col must be compatible with the range of the Array4d.
The range must be inside the whole range of the Array4d.
Example:
slip::Range<int> range(0,A1.dim4()-1,2);
//copy the the elements of the column 0 in the slab 0 and the slice 0 of A1 iterated
//in reverse order according to the range in the column 1 in the slab 1 and the slice 1 of A2
std::copy(A1.col_rbegin(0,0,0,range),A1.col_rend(0,0,0,range),A2.col_begin(1,1,1));
template<typename T>
const_reverse_col_range_iterator slip::Array4d< T >::col_rend ( const size_type  slab,
const size_type  slice,
const size_type  col,
const slip::Range< int > &  range 
) const

Returns a read-only iterator that points to the first element of the Range range of the col of a slice col in the slab slab and the slice slice in the Array4d. Iteration is done in the reverse element order according to the Range.

Parameters
slabslab coordinate of the line
sliceThe index of the slice.
colThe index of the column to iterate.
rangeRange of the column to iterate.
Returns
const_reverse_col_range_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Precondition
col must be compatible with the range of the Array4d.
The range must be inside the whole range of the Array4d.
Example:
slip::Range<int> range(0,A1.dim4()-1,2);
//copy the the elements of the column 0 in the slab 0 and the slice 0 of A1 iterated
//in reverse order according to the range in the column 1 in the slab 1 and the slice 1 of A2
std::copy(A1.col_rbegin(0,0,0,range),A1.col_rend(0,0,0,range),A2.col_begin(1,1,1));
template<typename T >
Array4d< T >::size_type slip::Array4d< T >::cols ( ) const
inline

Returns the number of columns (fourth dimension size) in the Array4d.

Definition at line 4715 of file Array4d.hpp.

template<typename T >
Array4d< T >::size_type slip::Array4d< T >::columns ( ) const
inline

Returns the number of columns (fourth dimension size) in the Array4d.

Definition at line 4720 of file Array4d.hpp.

template<typename T >
Array4d< T >::size_type slip::Array4d< T >::dim1 ( ) const
inline

Returns the number of slabs (first dimension size, called time dimension too) in the Array4d.

Definition at line 4680 of file Array4d.hpp.

template<typename T >
Array4d< T >::size_type slip::Array4d< T >::dim2 ( ) const
inline

Returns the number of slices (second dimension size) in the Array4d.

Definition at line 4690 of file Array4d.hpp.

template<typename T >
Array4d< T >::size_type slip::Array4d< T >::dim3 ( ) const
inline

Returns the number of rows (third dimension size) in the Array4d.

Definition at line 4700 of file Array4d.hpp.

template<typename T >
Array4d< T >::size_type slip::Array4d< T >::dim4 ( ) const
inline

Returns the number of columns (fourth dimension size) in the Array4d.

Definition at line 4710 of file Array4d.hpp.

template<typename T >
bool slip::Array4d< T >::empty ( ) const
inline

Returns true if the Array4d is empty. (Thus size() == 0)

Definition at line 4738 of file Array4d.hpp.

template<typename T >
Array4d< T >::iterator slip::Array4d< T >::end ( )
inline

Returns a read/write iterator that points one past the last element in the Array4d. Iteration is done in ordinary element order.

Returns
end iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Example:
slip::Array4d<double> A1(10,9,5,2);
slip::Array4d<double> A2(10,9,5,2);
slip::Array4d<double> S(10,9,5,2);
//copy the sum of A1 and A2 in S
std::transform(A1.begin(),A1.end(),
A2.begin(),S.begin(),
std::plus<double>());

Definition at line 3411 of file Array4d.hpp.

template<typename T >
Array4d< T >::const_iterator slip::Array4d< T >::end ( ) const
inline

Returns a read-only (constant) iterator that points one past the last element in the Array4d. Iteration is done in ordinary element order.

Returns
const end iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Example:
slip::Array4d<double> A1(10,9,5,2);
slip::Array4d<double> A2(10,9,5,2);
slip::Array4d<double> S(10,9,5,2);
//copy the sum of A1 and A2 in S
std::transform(A1.begin(),A1.end(),
A2.begin(),S.begin(),
std::plus<double>());

Definition at line 3397 of file Array4d.hpp.

template<typename T>
void slip::Array4d< T >::fill ( const T &  value)
inline

Fills the container range [begin(),begin()+size()) with copies of value.

Parameters
valueA reference-to-const of arbitrary type.

Definition at line 2924 of file Array4d.hpp.

template<typename T>
void slip::Array4d< T >::fill ( const T *  value)
inline

Fills the container range [begin(),begin()+size()) with a copy of the value array.

Parameters
valueA pointer of arbitrary type.

Definition at line 2935 of file Array4d.hpp.

template<typename T>
template<typename InputIterator >
void slip::Array4d< T >::fill ( InputIterator  first,
InputIterator  last 
)
inline

Fills the container range [begin(),begin()+size()) with a copy of the range [first,last)

Parameters
firstAn input iterator.
lastAn input iterator.

Definition at line 2949 of file Array4d.hpp.

template<typename T >
Array4d< T >::iterator4d slip::Array4d< T >::first_front_upper_left ( )
inline

Returns a read/write iterator4d that points to the first element of the Array4d. It points to the first front upper left element of the Array4d.

Returns
iterator4d value
Remarks
This iterator is compatible with BidirectionalIterator algorithms.
Example
//Print M
std::copy(M.first_front_upper_left(),M.last_back_bottom_right(),
std::ostream_iterator<double>(std::cout," "));

Definition at line 4341 of file Array4d.hpp.

template<typename T >
Array4d< T >::const_iterator4d slip::Array4d< T >::first_front_upper_left ( ) const
inline

Returns a read-only iterator4d that points to the first element of the Array4d. It points to the fist front upper left element of the Array4d.

Returns
const iterator4d value
Remarks
This iterator is compatible with BidirectionalIterator algorithms.
Example
//Print M
std::copy(M.first_front_upper_left(),M.last_back_bottom_right(),
std::ostream_iterator<double>(std::cout," "));

Definition at line 4348 of file Array4d.hpp.

template<typename T >
Array4d< T >::iterator4d slip::Array4d< T >::first_front_upper_left ( const Box4d< int > &  box)
inline

Returns a read/write iterator4d that points to the first element of the Array4d. It points to the first front upper left element of the Box4d associated to the Array4d.

Parameters
boxA Box4d defining the range of indices to iterate within the Array4d.
Remarks
This iterator is compatible with BidirectionalIterator algorithms.
Returns
iterator4d value
Precondition
The box indices must be inside the range of the Array4d ones.
Example
slip::Box4d<int> b(1,1,1,1,2,2,3,3);
//Print M values within the box
std::copy(M.first_front_upper_left(b),M.last_back_bottom_right(b),
std::ostream_iterator<double>(std::cout," "));

Definition at line 4410 of file Array4d.hpp.

template<typename T >
Array4d< T >::const_iterator4d slip::Array4d< T >::first_front_upper_left ( const Box4d< int > &  box) const
inline

Returns a read only iterator4d that points to the first element of the Array4d. It points to the front upper left element of the Box4d associated to the Array4d.

Parameters
boxa Box4d defining the range of indices to iterate within the Array4d.
Returns
end const iterator4d value
Remarks
This iterator is compatible with BidirectionalIterator algorithms.
Precondition
The box indices must be inside the range of the Array4d ones.
Example
slip::Box4d<int> b(1,1,1,1,2,2,3,3);
//Print M values within the box
std::copy(M.first_front_upper_left(b),M.last_back_bottom_right(b),
std::ostream_iterator<double>(std::cout," "));

Definition at line 4417 of file Array4d.hpp.

template<typename T>
iterator4d_range slip::Array4d< T >::first_front_upper_left ( const range slab_range,
const range slice_range,
const range row_range,
const range col_range 
)

Returns a read/write iterator4d_range that points to the first front upper left element of the ranges slab_range, slice_range, row_range and col_range associated to the Array4d.

Parameters
slab_rangeThe range of the slices.
slice_rangeThe range of the slices.
row_rangeThe range of the rows.
col_rangeThe range of the columns.
Precondition
slab_range, slice_range, row_range and col_range must be valid.
The ranges indices must be inside the ranges of the Array4d ones.
Returns
iterator4d_range value
Remarks
This iterator is compatible with BidirectionalIterator algorithms.
Example
slip::Range<int> slar(0,2,2);
slip::Range<int> slir(0,2,2);
slip::Range<int> rr(0,3,2);
slip::Range<int> cr(0,4,2);
//Print M within a range
std::copy(M.first_front_upper_left(slar,slir,rr,cr),M.last_back_bottom_right(slar,slir,rr,cr),
std::ostream_iterator<double>(std::cout," "));
template<typename T>
const_iterator4d_range slip::Array4d< T >::first_front_upper_left ( const range slab_range,
const range slice_range,
const range row_range,
const range col_range 
) const

Returns a read-only iterator4d_range that points to the to the first front upper left element of the ranges slab_range, slice_range, row_range and col_range associated to the Array4d.

Parameters
slab_rangeThe range of the slices.
slice_rangeThe range of the slices.
row_rangeThe range of the rows.
col_rangeThe range of the columns.
Precondition
slab_range, slice_range, row_range and col_range must be valid.
The ranges indices must be inside the ranges of the Array4d ones.
Returns
const_iterator4d_range value
Remarks
This iterator is compatible with BidirectionalIterator algorithms.
Example
slip::Range<int> slar(0,2,2);
slip::Range<int> slir(0,2,2);
slip::Range<int> rr(0,3,2);
slip::Range<int> cr(0,4,2);
//Print M within a range
std::copy(M.first_front_upper_left(slar,slir,rr,cr),M.last_back_bottom_right(slar,slir,rr,cr),
std::ostream_iterator<double>(std::cout," "));
template<typename T >
Array4d< T >::iterator4d slip::Array4d< T >::last_back_bottom_right ( )
inline

Returns a read/write iterator4d that points to the past the end element of the Array4d. It points to past the end element of the last back bottom right element of the Array4d.

Returns
iterator4d value
Remarks
This iterator is compatible with BidirectionalIterator algorithms.
Example
//Print M
std::copy(M.first_front_upper_left(),M.last_back_bottom_right(),
std::ostream_iterator<double>(std::cout," "));

Definition at line 4356 of file Array4d.hpp.

template<typename T >
Array4d< T >::const_iterator4d slip::Array4d< T >::last_back_bottom_right ( ) const
inline

Returns a read-only iterator4d that points to the past the end element of the Array4d. It points to past the end element of the last back bottom right element of the Array4d.

Returns
const iterator4d value
Remarks
This iterator is compatible with BidirectionalIterator algorithms.
Example
//Print M
std::copy(M.first_front_upper_left(),M.last_back_bottom_right(),
std::ostream_iterator<double>(std::cout," "));

Definition at line 4365 of file Array4d.hpp.

template<typename T >
Array4d< T >::iterator4d slip::Array4d< T >::last_back_bottom_right ( const Box4d< int > &  box)
inline

Returns a read/write iterator4d that points to the past the end element of the Array4d. It points to past the end element of the last back bottom right element of the Box4d associated to the Array4d.

Parameters
boxa Box4d defining the range of indices to iterate within the Array4d.
Returns
iterator4d value
Remarks
This iterator is compatible with BidirectionalIterator algorithms.
Precondition
The box indices must be inside the range of the Array4d ones.
Example
slip::Box4d<int> b(1,1,1,1,2,2,3,3);
//Print M values within the box
std::copy(M.first_front_upper_left(b),M.last_back_bottom_right(b),
std::ostream_iterator<double>(std::cout," "));

Definition at line 4426 of file Array4d.hpp.

template<typename T >
Array4d< T >::const_iterator4d slip::Array4d< T >::last_back_bottom_right ( const Box4d< int > &  box) const
inline

Returns a read only iterator4d that points to the past the end element of the Array4d. It points to past the end element of the back bottom right element of the Box4d associated to the Array4d.

Parameters
boxa Box4d defining the range of indices to iterate within the Array4d.
Returns
end const iterator4d value
Remarks
This iterator is compatible with BidirectionalIterator algorithms.
Precondition
The box indices must be inside the range of the Array4d ones.
Example
slip::Box4d<int> b(1,1,1,1,2,2,3,3);
//Print M values within the box
std::copy(M.first_front_upper_left(b),M.last_back_bottom_right(b),
std::ostream_iterator<double>(std::cout," "));

Definition at line 4436 of file Array4d.hpp.

template<typename T>
iterator4d_range slip::Array4d< T >::last_back_bottom_right ( const range slab_range,
const range slice_range,
const range row_range,
const range col_range 
)

Returns a read/write iterator4d_range that points to the past the end last back bottom right element of the ranges slab_range, slice_range, row_range and col_range associated to the Array4d.

Parameters
slab_rangeThe range of the slices.
slice_rangeThe range of the slices.
row_rangeThe range of the rows.
col_rangeThe range of the columns.
Precondition
slab_range, slice_range, row_range and col_range must be valid.
The ranges indices must be inside the ranges of the Array4d ones.
Returns
iterator4d_range value
Remarks
This iterator is compatible with BidirectionalIterator algorithms.
Example
slip::Range<int> slar(0,2,2);
slip::Range<int> slir(0,2,2);
slip::Range<int> rr(0,3,2);
slip::Range<int> cr(0,4,2);
//Print M within a range
std::copy(M.first_front_upper_left(slar,slir,rr,cr),M.last_back_bottom_right(slar,slir,rr,cr),
std::ostream_iterator<double>(std::cout," "));
template<typename T>
const_iterator4d_range slip::Array4d< T >::last_back_bottom_right ( const range slab_range,
const range slice_range,
const range row_range,
const range col_range 
) const

Returns a read-only iterator4d_range that points to the past the end last back bottom right element of the ranges slab_range, slice_range, row_range and col_range associated to the Array4d.

Parameters
slab_rangeThe range of the slices.
slice_rangeThe range of the slices.
row_rangeThe range of the rows.
col_rangeThe range of the columns.
Precondition
slab_range, slice_range, row_range and col_range must be valid.
The ranges indices must be inside the ranges of the Array4d ones.
Returns
const_iterator4d_range value
Remarks
This iterator is compatible with BidirectionalIterator algorithms.
Example
slip::Range<int> slar(0,2,2);
slip::Range<int> slir(0,2,2);
slip::Range<int> rr(0,3,2);
slip::Range<int> cr(0,4,2);
//Print M within a range
std::copy(M.first_front_upper_left(slar,slir,rr,cr),M.last_back_bottom_right(slar,slir,rr,cr),
std::ostream_iterator<double>(std::cout," "));
template<typename T >
Array4d< T >::size_type slip::Array4d< T >::max_size ( ) const
inline

Returns the maximal size (number of elements) in the Array4d.

Definition at line 4731 of file Array4d.hpp.

template<typename T >
std::string slip::Array4d< T >::name ( ) const
inline

Returns the name of the class.

Definition at line 4674 of file Array4d.hpp.

template<typename T>
reference slip::Array4d< T >::operator() ( const size_type  l,
const size_type  k,
const size_type  i,
const size_type  j 
)

Subscript access to the data contained in the Array4d.

Parameters
lThe index of the slab for which the data should be accessed.
kThe index of the slice for which the data should be accessed.
iThe index of the row for which the data should be accessed.
jThe index of the column for which the data should be accessed.
Returns
Read/Write reference to data.
Precondition
l < slabs()
k < slices()
i < rows()
j < cols() This operator allows for easy, 4d array-style, data access. Note that data access with this operator is unchecked and out_of_range lookups are not defined.
template<typename T>
const_reference slip::Array4d< T >::operator() ( const size_type  l,
const size_type  k,
const size_type  i,
const size_type  j 
) const

Subscript access to the data contained in the Array4d.

Parameters
lThe index of the slab for which the data should be accessed.
kThe index of the slice for which the data should be accessed.
iThe index of the row for which the data should be accessed.
jThe index of the column for which the data should be accessed.
Returns
Read_only (constant) reference to data.
Precondition
l < slabs()
k < slices()
i < rows()
j < cols() This operator allows for easy, 4d array-style, data access. Note that data access with this operator is unchecked and out_of_range lookups are not defined.
template<typename T>
Array4d< T > & slip::Array4d< T >::operator= ( const Array4d< T > &  rhs)
inline

Assign a Array4d.

Assign elements of Array4d in rhs

Parameters
rhsArray4d to get the values from.
Returns

Definition at line 3321 of file Array4d.hpp.

template<typename T>
Array4d< T > & slip::Array4d< T >::operator= ( const T &  value)
inline

Assign all the elments of the Array4d by value.

Parameters
valueA reference-to-const of arbitrary type.
Returns

Definition at line 3341 of file Array4d.hpp.

template<typename T>
T*** slip::Array4d< T >::operator[] ( const size_type  l)
template<typename T>
const T** const* slip::Array4d< T >::operator[] ( const size_type  l) const
template<typename T >
Array4d< T >::reverse_iterator slip::Array4d< T >::rbegin ( )
inline

Returns a read/write reverse iterator that points to the last element in the Array4d. Iteration is done in reverse element order.

Returns
reverse begin iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Example:
slip::Array4d<double> A1(10,9,5,2);
slip::Array4d<double> A2(10,9,5,2);
slip::Array4d<double> S(10,9,5,2);
//copy the sum of A1 and A2 in S
std::transform(A1.rbegin(),A1.rend(),
A2.rbegin(),S.rbegin(),
std::plus<double>());

Definition at line 3418 of file Array4d.hpp.

template<typename T >
Array4d< T >::const_reverse_iterator slip::Array4d< T >::rbegin ( ) const
inline

Returns a read-only (constant) reverse iterator that points to the last element in the Array4d. Iteration is done in reverse element order.

Returns
const reverse begin iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Example:
slip::Array4d<double> A1(10,9,5,2);
slip::Array4d<double> A2(10,9,5,2);
slip::Array4d<double> S(10,9,5,2);
//copy the sum of A1 and A2 in S
std::transform(A1.rbegin(),A1.rend(),
A2.rbegin(),S.rbegin(),
std::plus<double>());

Definition at line 3425 of file Array4d.hpp.

template<typename T >
Array4d< T >::reverse_iterator slip::Array4d< T >::rend ( )
inline

Returns a read/write reverse iterator that points to one before the first element in the Array4d. Iteration is done in reverse element order.

Returns
reverse end iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Example:
slip::Array4d<double> A1(10,9,5,2);
slip::Array4d<double> A2(10,9,5,2);
slip::Array4d<double> S(10,9,5,2);
//copy the sum of A1 and A2 in S
std::transform(A1.rbegin(),A1.rend(),
A2.rbegin(),S.rbegin(),
std::plus<double>());

Definition at line 3432 of file Array4d.hpp.

template<typename T >
Array4d< T >::const_reverse_iterator slip::Array4d< T >::rend ( ) const
inline

Returns a read-only (constant) reverse iterator that points to one before the first element in the Array4d. Iteration is done in reverse element order.

Returns
const reverse end iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Example:
slip::Array4d<double> A1(10,9,5,2);
slip::Array4d<double> A2(10,9,5,2);
slip::Array4d<double> S(10,9,5,2);
//copy the sum of A1 and A2 in S
std::transform(A1.rbegin(),A1.rend(),
A2.rbegin(),S.rbegin(),
std::plus<double>());

Definition at line 3440 of file Array4d.hpp.

template<typename T>
void slip::Array4d< T >::resize ( std::size_t  d1,
std::size_t  d2,
std::size_t  d3,
std::size_t  d4,
const T &  val = T() 
)
inline

Resizes a Array4d.

Parameters
d1new first dimension
d2new second dimension
d3new third dimension
d4new fourth dimension
valnew value for all the elements

Definition at line 3351 of file Array4d.hpp.

template<typename T >
Array4d< T >::reverse_iterator4d slip::Array4d< T >::rfirst_front_upper_left ( )
inline

Returns a read/write reverse iterator4d. It points to the last back bottom right element of the Array4d. Iteration is done within the Array4d in the reverse order.

Returns
reverse_iterator4d value
Remarks
This iterator is compatible with BidirectionalIterator algorithms.
Example
//Print M in a reverse order
std::copy(M.rfirst_front_upper_left(),M.rlast_back_bottom_right(),
std::ostream_iterator<double>(std::cout," "));

Definition at line 4391 of file Array4d.hpp.

template<typename T >
Array4d< T >::const_reverse_iterator4d slip::Array4d< T >::rfirst_front_upper_left ( ) const
inline

Returns a read only reverse iterator4d that points. It points to the last back bottom right element of the Array4d. Iteration is done within the Array4d in the reverse order.

Returns
const_reverse_iterator4d value
Remarks
This iterator is compatible with BidirectionalIterator algorithms.
Example
//Print M in a reverse order
std::copy(M.rfirst_front_upper_left(),M.rlast_back_bottom_right(),
std::ostream_iterator<double>(std::cout," "));

Definition at line 4400 of file Array4d.hpp.

template<typename T >
Array4d< T >::reverse_iterator4d slip::Array4d< T >::rfirst_front_upper_left ( const Box4d< int > &  box)
inline

Returns a read/write reverse iterator4d. It points to the back bottom right element of the Box4d associated to the Array4d. Iteration is done in the reverse order.

Parameters
boxa Box4d defining the range of indices to iterate within the Array4d.
Precondition
The box indices must be inside the range of the Array4d ones.
Returns
reverse iterator4d value
Remarks
This iterator is compatible with BidirectionalIterator algorithms.
Example
slip::Box4d<int> b(1,1,1,1,2,2,3,3);
//Print M values within the box in reverse order.
std::copy(M.rfirst_front_upper_left(b),M.rlast_back_bottom_right(b),
std::ostream_iterator<double>(std::cout," "));

Definition at line 4462 of file Array4d.hpp.

template<typename T >
Array4d< T >::const_reverse_iterator4d slip::Array4d< T >::rfirst_front_upper_left ( const Box4d< int > &  box) const
inline

Returns a read only reverse iterator4d. It points to the back bottom right element of the Box4d box associated to the Array4d. Iteration is done in the reverse order.

Parameters
boxA Box4d defining the range of indices to iterate within the Array4d.
Precondition
The box indices must be inside the range of the Array4d ones.
Returns
const reverse iterator4d value
Remarks
This iterator is compatible with BidirectionalIterator algorithms.
Example
slip::Box4d<int> b(1,1,1,1,2,2,3,3);
//Print M values within the box in reverse order.
std::copy(M.rfirst_front_upper_left(b),M.rlast_back_bottom_right(b),
std::ostream_iterator<double>(std::cout," "));

Definition at line 4471 of file Array4d.hpp.

template<typename T>
reverse_iterator4d_range slip::Array4d< T >::rfirst_front_upper_left ( const range slab_range,
const range slice_range,
const range row_range,
const range col_range 
)

Returns a read/write reverse_iterator4d_range that points to the past the last back bottom right element of the ranges slab_range, slice_range, row_range and col_range associated to the Array4d. Iteration is done in the reverse order.

Parameters
slab_rangeThe range of the slices.
slice_rangeThe range of the slices.
row_rangeThe range of the rows.
col_rangeThe range of the columns.
Precondition
slab_range, slice_range, row_range and col_range must be valid.
The ranges indices must be inside the ranges of the Array4d ones.
Returns
reverse_iterator4d_range value
Remarks
This iterator is compatible with BidirectionalIterator algorithms.
Example
slip::Range<int> slar(0,2,2);
slip::Range<int> slir(0,2,2);
slip::Range<int> rr(0,3,2);
slip::Range<int> cr(0,4,2);
//Print M within a range in reverse order
std::copy(M.rfirst_front_upper_left(slar,slir,rr,cr),M.rlast_back_bottom_right(slar,slir,rr,cr),
std::ostream_iterator<double>(std::cout," "));
template<typename T>
const_reverse_iterator4d_range slip::Array4d< T >::rfirst_front_upper_left ( const range slab_range,
const range slice_range,
const range row_range,
const range col_range 
) const

Returns a read-only reverse_iterator4d_range that points to the past the last back bottom right element of the ranges slab_range, slice_range, row_range and col_range associated to the Array4d. Iteration is done in the reverse order.

Parameters
slab_rangeThe range of the slices.
slice_rangeThe range of the slices.
row_rangeThe range of the rows.
col_rangeThe range of the columns.
Precondition
slab_range, slice_range, row_range and col_range must be valid.
The ranges indices must be inside the ranges of the Array4d ones.
Returns
const_reverse_iterator4d_range value
Remarks
This iterator is compatible with BidirectionalIterator algorithms.
Example
slip::Range<int> slar(0,2,2);
slip::Range<int> slir(0,2,2);
slip::Range<int> rr(0,3,2);
slip::Range<int> cr(0,4,2);
//Print M within a range in reverse order
std::copy(M.rfirst_front_upper_left(slar,slir,rr,cr),M.rlast_back_bottom_right(slar,slir,rr,cr),
std::ostream_iterator<double>(std::cout," "));
template<typename T >
Array4d< T >::reverse_iterator4d slip::Array4d< T >::rlast_back_bottom_right ( )
inline

Returns a read/write reverse iterator4d. It points to past the first front upper left element of the Array4d. Iteration is done in the reverse order.

Returns
reverse iterator4d value
Remarks
This iterator is compatible with BidirectionalIterator algorithms.
Example
//Print M in a reverse order
std::copy(M.rfirst_front_upper_left(),M.rlast_back_bottom_right(),
std::ostream_iterator<double>(std::cout," "));

Definition at line 4375 of file Array4d.hpp.

template<typename T >
Array4d< T >::const_reverse_iterator4d slip::Array4d< T >::rlast_back_bottom_right ( ) const
inline

Returns a read only reverse iterator4d. It points to past the first front upper left element of the Array4d. Iteration is done in the reverse order.

Returns
const reverse iterator4d value
Remarks
This iterator is compatible with BidirectionalIterator algorithms.
Example
//Print M in a reverse order
std::copy(M.rfirst_front_upper_left(),M.rlast_back_bottom_right(),
std::ostream_iterator<double>(std::cout," "));

Definition at line 4383 of file Array4d.hpp.

template<typename T >
Array4d< T >::reverse_iterator4d slip::Array4d< T >::rlast_back_bottom_right ( const Box4d< int > &  box)
inline

Returns a read/write reverse iterator4d. It points to one before the front upper left element of the Box4d box associated to the Array4d.

Parameters
boxA Box4d defining the range of indices to iterate within the Array4d.
Precondition
The box indices must be inside the range of the Array4d ones.
Returns
reverse iterator4d value
Remarks
This iterator is compatible with BidirectionalIterator algorithms.
Example
slip::Box4d<int> b(1,1,1,1,2,2,3,3);
//Print M values within the box in reverse order.
std::copy(M.rfirst_front_upper_left(b),M.rlast_back_bottom_right(b),
std::ostream_iterator<double>(std::cout," "));

Definition at line 4446 of file Array4d.hpp.

template<typename T >
Array4d< T >::const_reverse_iterator4d slip::Array4d< T >::rlast_back_bottom_right ( const Box4d< int > &  box) const
inline

Returns a read-only reverse iterator4d. It points to one before the front element of the bottom right element of the Box4d box associated to the Array4d.

Parameters
boxA Box4d defining the range of indices to iterate within the Array4d.
Precondition
The box indices must be inside the range of the Array4d ones.
Returns
const reverse iterator4d value
Remarks
This iterator is compatible with BidirectionalIterator algorithms.
Example
slip::Box4d<int> b(1,1,1,1,2,2,3,3);
//Print M values within the box in reverse order.
std::copy(M.rfirst_front_upper_left(b),M.rlast_back_bottom_right(b),
std::ostream_iterator<double>(std::cout," "));

Definition at line 4454 of file Array4d.hpp.

template<typename T>
reverse_iterator4d_range slip::Array4d< T >::rlast_back_bottom_right ( const range slab_range,
const range slice_range,
const range row_range,
const range col_range 
)

Returns a read/write reverse_iterator4d_range that points to one before the first front upper left element of the ranges slab_range, slice_range, row_range and col_range associated to the Array4d. Iteration is done in the reverse order.

Parameters
slab_rangeThe range of the slices.
slice_rangeThe range of the slices.
row_rangeThe range of the rows.
col_rangeThe range of the columns.
Precondition
slab_range, slice_range, row_range and col_range must be valid.
The ranges indices must be inside the ranges of the Array4d ones.
Returns
reverse_iterator4d_range value
Remarks
This iterator is compatible with BidirectionalIterator algorithms.
Example
slip::Range<int> slar(0,2,2);
slip::Range<int> slir(0,2,2);
slip::Range<int> rr(0,3,2);
slip::Range<int> cr(0,4,2);
//Print M within a range in reverse order
std::copy(M.rfirst_front_upper_left(slar,slir,rr,cr),M.rlast_back_bottom_right(slar,slir,rr,cr),
std::ostream_iterator<double>(std::cout," "));
template<typename T>
const_reverse_iterator4d_range slip::Array4d< T >::rlast_back_bottom_right ( const range slab_range,
const range slice_range,
const range row_range,
const range col_range 
) const

Returns a read-only reverse_iterator4d_range that points to one before the first front upper left element of the ranges slab_range, slice_range, row_range and col_range associated to the Array4d. Iteration is done in the reverse order.

Parameters
slab_rangeThe range of the slices.
slice_rangeThe range of the slices.
row_rangeThe range of the rows.
col_rangeThe range of the columns.
Precondition
slab_range, slice_range, row_range and col_range must be valid.
The ranges indices must be inside the ranges of the Array4d ones.
Returns
const_reverse_iterator4d_range value
Remarks
This iterator is compatible with BidirectionalIterator algorithms.
Example
slip::Range<int> slar(0,2,2);
slip::Range<int> slir(0,2,2);
slip::Range<int> rr(0,3,2);
slip::Range<int> cr(0,4,2);
//Print M within a range in reverse order
std::copy(M.rfirst_front_upper_left(slar,slir,rr,cr),M.rlast_back_bottom_right(slar,slir,rr,cr),
std::ostream_iterator<double>(std::cout," "));
template<typename T>
row_iterator slip::Array4d< T >::row_begin ( const size_type  slab,
const size_type  slice,
const size_type  row 
)

Returns a read/write iterator that points to the first element of the row row of a given slab slab and a given slice slice in the Array4d. Iteration is done in ordinary element order.

Parameters
slabThe index of the slab.
sliceThe index of the slice.
rowThe index of the row.
Returns
begin row_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Note
The row and col iterators iterate in the rows and columns respectively. There are different from slab and slice iterators that cross the slabs and slices respectively.
template<typename T>
const_row_iterator slip::Array4d< T >::row_begin ( const size_type  slab,
const size_type  slice,
const size_type  row 
) const

Returns a read_only iterator that points to the first element of the row row of a given slab slab and a given slice slice in the Array4d. Iteration is done in ordinary element order.

Parameters
slabThe index of the slab.
sliceThe index of the slice.
rowThe index of the row.
Returns
begin const_row_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Note
The row and col iterators iterate in the rows and columns respectively. There are different from slab and slice iterators that cross the slabs and slices respectively.
template<typename T>
row_range_iterator slip::Array4d< T >::row_begin ( const size_type  slab,
const size_type  slice,
const size_type  row,
const slip::Range< int > &  range 
)

Returns a read/write iterator that points to the first element of the Range range of the row row in the slab slab and the slice slice in the Array4d. Iteration is done in ordinary element order according to the Range.

Parameters
slabslab coordinate of the line
sliceThe index of the slice.
rowThe index of the row to iterate.
rangeRange of the row to iterate.
Returns
begin row_range_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Precondition
row must be compatible with the range of the Array4d.
The range must be inside the whole range of the Array4d.
Example:
slip::Array4d<double> A1(8,8,8,8);
slip::Array4d<double> A2(5,4,8,4);
slip::Range<int> range(0,A1.dim3()-1,2);
//copy the the elements of the row 0 of the slab 0 and the slice 0 of A1 iterated according to the
//range in the row 1 of the slab 1 and slice 1 of A2
std::copy(A1.row_begin(0,0,0,range),A1.row_end(0,0,0,range),A2.row_begin(1,1,1));
template<typename T>
const_row_range_iterator slip::Array4d< T >::row_begin ( const size_type  slab,
const size_type  slice,
const size_type  row,
const slip::Range< int > &  range 
) const

Returns a read-only iterator that points to the first element of the Range range of the row row in the slab slab and the slice slice in the Array4d. Iteration is done in ordinary element order according to the Range.

Parameters
slabslab coordinate of the line
sliceThe index of the slice.
rowThe index of the row to iterate.
rangeRange of the row to iterate.
Returns
begin const_row_range_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Precondition
row must be compatible with the range of the Array4d.
The range must be inside the whole range of the Array4d.
Example:
slip::Array4d<double> A1(8,8,8,8);
slip::Array4d<double> A2(5,4,8,4);
slip::Range<int> range(0,A1.dim3()-1,2);
//copy the the elements of the row 0 of the slab 0 and the slice 0 of A1 iterated according to the
//range in the row 1 of the slab 1 and slice 1 of A2
std::copy(A1.row_begin(0,0,0,range),A1.row_end(0,0,0,range),A2.row_begin(1,1,1));
template<typename T>
row_iterator slip::Array4d< T >::row_end ( const size_type  slab,
const size_type  slice,
const size_type  row 
)

Returns a read/write iterator that points to the past-the-end element of the row row of a given slab slab and a given slice slice in the Array4d. Iteration is done in ordinary element order.

Parameters
slabThe index of the slab.
sliceThe index of the slice.
rowThe index of the row.
Returns
end row_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Note
The row and col iterators iterate in the rows and columns respectively. There are different from slab and slice iterators that cross the slabs and slices respectively.
template<typename T>
const_row_iterator slip::Array4d< T >::row_end ( const size_type  slab,
const size_type  slice,
const size_type  row 
) const

Returns a read_only iterator that points to the past-the-end element of the row row of a given slab slab and a given slice slice in the Array4d. Iteration is done in ordinary element order.

Parameters
slabThe index of the slab.
sliceThe index of the slice.
rowThe index of the row.
Returns
end const_row_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Note
The row and col iterators iterate in the rows and columns respectively. There are different from slab and slice iterators that cross the slabs and slices respectively.
template<typename T>
row_range_iterator slip::Array4d< T >::row_end ( const size_type  slab,
const size_type  slice,
const size_type  row,
const slip::Range< int > &  range 
)

Returns a read/write iterator that points one past the end element of the Range range of the row row in the slab slab and the slice slice in the Array4d. Iteration is done in ordinary element order according to the Range.

Parameters
slabslab coordinate of the line
sliceThe index of the slice.
rowThe index of the row to iterate.
rangeRange of the row to iterate.
Returns
end row_range_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Precondition
row must be compatible with the range of the Array4d.
The range must be inside the whole range of the Array4d.
Example:
slip::Array4d<double> A1(8,8,8,8);
slip::Array4d<double> A2(5,4,8,4);
slip::Range<int> range(0,A1.dim3()-1,2);
//copy the the elements of the row 0 of the slab 0 and the slice 0 of A1 iterated according to the
//range in the row 1 of the slab 1 and slice 1 of A2
std::copy(A1.row_begin(0,0,0,range),A1.row_end(0,0,0,range),A2.row_begin(1,1,1));
template<typename T>
const_row_range_iterator slip::Array4d< T >::row_end ( const size_type  slab,
const size_type  slice,
const size_type  row,
const slip::Range< int > &  range 
) const

Returns a read_only iterator that points one past the last element of the Range range of the row row in the slab slab and the slice slice in the Array4d. Iteration is done in ordinary element order according to the Range.

Parameters
slabslab coordinate of the line
sliceThe index of the slice.
rowRow to iterate.
rangeRange of the row to iterate
Returns
begin const_row_range_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Precondition
row must be compatible with the range of the Array4d.
The range must be inside the whole range of the Array4d.
Example:
slip::Array4d<double> A1(8,8,8,8);
slip::Array4d<double> A2(5,4,8,4);
slip::Range<int> range(0,A1.dim3()-1,2);
//copy the the elements of the row 0 of the slab 0 and the slice 0 of A1 iterated according to the
//range in the row 1 of the slab 1 and slice 1 of A2
std::copy(A1.row_begin(0,0,0,range),A1.row_end(0,0,0,range),A2.row_begin(1,1,1));
template<typename T>
reverse_row_iterator slip::Array4d< T >::row_rbegin ( const size_type  slab,
const size_type  slice,
const size_type  row 
)

Returns a read/write reverse iterator that points to the last element of the row row of a given slab slab and a given slice slice in the Array4d. Iteration is done in reverse element order.

Parameters
slabThe index of the slab.
sliceThe index of the slice.
rowThe index of the row.
Returns
begin reverse_row_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Note
The row and col iterators iterate in the rows and columns respectively. There are different from slab and slice iterators that cross the slabs and slices respectively.
template<typename T>
const_reverse_row_iterator slip::Array4d< T >::row_rbegin ( const size_type  slab,
const size_type  slice,
const size_type  row 
) const

Returns a read_only reverse iterator that points to the last element of the row row of a given slab slab and a given slice slice in the Array4d. Iteration is done in reverse element order.

Parameters
slabThe index of the slab.
sliceThe index of the slice.
rowThe index of the row.
Returns
begin const_reverse_row_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Note
The row and col iterators iterate in the rows and columns respectively. There are different from slab and slice iterators that cross the slabs and slices respectively.
template<typename T>
reverse_row_range_iterator slip::Array4d< T >::row_rbegin ( const size_type  slab,
const size_type  slice,
const size_type  row,
const slip::Range< int > &  range 
)

Returns a read-write iterator that points to the last element of the Range range of the row row in the slab slab and the slice slice in the Array4d. Iteration is done in the reverse element order according to the Range.

Parameters
slabslab coordinate of the line
sliceThe index of the slice.
rowThe index of the row to iterate.
rangeRange of the row to iterate.
Returns
reverse_row_range_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Precondition
row must be compatible with the range of the Array4d.
The range must be inside the whole range of the Array4d.
Example:
slip::Array4d<double> A1(8,8,8,8);
slip::Array4d<double> A2(5,4,8,4);
slip::Range<int> range(0,A1.dim3()-1,2);
//copy the the elements of the row 0 of the slab 0 and the slice 0 of A1 iterated
in reverse order according to the range in the row 1 of the slab 1 and slice 1 of A2
std::copy(A1.row_rbegin(0,0,0,range),A1.row_rend(0,0,0,range),A2.row_begin(1,1,1));
template<typename T>
const_reverse_row_range_iterator slip::Array4d< T >::row_rbegin ( const size_type  slab,
const size_type  slice,
const size_type  row,
const slip::Range< int > &  range 
) const

Returns a read-only iterator that points to the last element of the Range range of the row row in the slab slab and the slice slice in the Array4d. Iteration is done in the reverse element order according to the Range.

Parameters
slabslab coordinate of the line
sliceThe index of the slice.
rowThe index of the row to iterate.
rangeRange of the row to iterate
Returns
begin const_reverse_row_range_iterator value
Precondition
row must be compatible with the range of the Array4d.
The range must be inside the whole range of the Array4d.
Example:
slip::Array4d<double> A1(8,8,8,8);
slip::Array4d<double> A2(5,4,8,4);
slip::Range<int> range(0,A1.dim3()-1,2);
//copy the the elements of the row 0 of the slab 0 and the slice 0 of A1 iterated
in reverse order according to the range in the row 1 of the slab 1 and slice 1 of A2
std::copy(A1.row_rbegin(0,0,0,range),A1.row_rend(0,0,0,range),A2.row_begin(1,1,1));
template<typename T>
reverse_row_iterator slip::Array4d< T >::row_rend ( const size_type  slab,
const size_type  slice,
const size_type  row 
)

Returns a read/write reverse iterator that points to the first element of the row row of a given slab slab and a given slice slice in the Array4d. Iteration is done in reverse element order.

Parameters
slabThe index of the slab.
sliceThe index of the slice.
rowThe index of the row.
Returns
end reverse_row_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Note
The row and col iterators iterate in the rows and columns respectively. There are different from slab and slice iterators that cross the slabs and slices respectively.
template<typename T>
const_reverse_row_iterator slip::Array4d< T >::row_rend ( const size_type  slab,
const size_type  slice,
const size_type  row 
) const

Returns a read_only reverse iterator that points to the first element of the row row of a given slab slab and a given slice slice in the Array4d. Iteration is done in reverse element order.

Parameters
slabThe index of the slab.
sliceThe index of the slice.
rowThe index of the row.
Returns
end const_reverse_row_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Note
The row and col iterators iterate in the rows and columns respectively. There are different from slab and slice iterators that cross the slabs and slices respectively.
template<typename T>
reverse_row_range_iterator slip::Array4d< T >::row_rend ( const size_type  slab,
const size_type  slice,
const size_type  row,
const slip::Range< int > &  range 
)

Returns a read-write iterator that points one before the first element of the Range range of the row row in the slab slab and the slice slice in the Array4d. Iteration is done in the reverse element order according to the Range.

Parameters
slabslab coordinate of the line
sliceThe index of the slice.
rowThe index of the row to iterate.
rangeRange of the row to iterate.
Returns
reverse_row_range_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Precondition
row must be compatible with the range of the Array4d.
The range must be inside the whole range of the Array4d.
Example:
slip::Array4d<double> A1(8,8,8,8);
slip::Array4d<double> A2(5,4,8,4);
slip::Range<int> range(0,A1.dim3()-1,2);
//copy the the elements of the row 0 of the slab 0 and the slice 0 of A1 iterated
in reverse order according to the range in the row 1 of the slab 1 and slice 1 of A2
std::copy(A1.row_rbegin(0,0,0,range),A1.row_rend(0,0,0,range),A2.row_begin(1,1,1));
template<typename T>
const_reverse_row_range_iterator slip::Array4d< T >::row_rend ( const size_type  slab,
const size_type  slice,
const size_type  row,
const slip::Range< int > &  range 
) const

Returns a read-only iterator that points one before the first element of the Range range of the row row in the slab slab and the slice slice in the Array4d. Iteration is done in the reverse element order according to the Range.

Parameters
slabslab coordinate of the line
sliceThe index of the slice.
rowThe index of the row to iterate.
rangeRange of the row to iterate
Returns
const_reverse_row_range_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Precondition
row must be compatible with the range of the Array4d.
The range must be inside the whole range of the Array4d.
Example:
slip::Array4d<double> A1(8,8,8,8);
slip::Array4d<double> A2(5,4,8,4);
slip::Range<int> range(0,A1.dim3()-1,2);
//copy the the elements of the row 0 of the slab 0 and the slice 0 of A1 iterated
in reverse order according to the range in the row 1 of the slab 1 and slice 1 of A2
std::copy(A1.row_rbegin(0,0,0,range),A1.row_rend(0,0,0,range),A2.row_begin(1,1,1));
template<typename T >
Array4d< T >::size_type slip::Array4d< T >::rows ( ) const
inline

Returns the number of rows (third dimension size) in the Array4d.

Definition at line 4705 of file Array4d.hpp.

template<typename T >
Array4d< T >::size_type slip::Array4d< T >::size ( ) const
inline

Returns the number of elements in the Array4d.

Definition at line 4726 of file Array4d.hpp.

template<typename T>
slab_iterator slip::Array4d< T >::slab_begin ( const size_type  slice,
const size_type  row,
const size_type  col 
)

Returns a read/write iterator that points to the first element of the line (slice,row,col) through the slabs in the Array4d. Iteration is done in ordinary element order (increasing slab number).

Parameters
sliceslice coordinate of the line
rowrow coordinate of the line
colcol coordinate of the line
Returns
slab_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Example:
slip::Array4d<double> A1(10,9,5,2);
slip::Array4d<double> A2(10,9,5,2);
//calculate the sums of the A1 and A2 elements pairwise for the line crossing the slabs through the first slice,
the second row and the third column. Put the calculated sums in the S array.
std::transform(A1.slab_begin(0,1,2),A1.slab_end(0,1,2),
A2.slab_begin(0,1,2),S.begin(),
std::plus<double>());
template<typename T>
const_slab_iterator slip::Array4d< T >::slab_begin ( const size_type  slice,
const size_type  row,
const size_type  col 
) const

Returns a read-only (constant) iterator that points to the first element of the line (slice,row,col) through the slabs in the Array4d. Iteration is done in ordinary element order (increasing slab number).

Parameters
sliceslice coordinate of the line
rowrow coordinate of the line
colcol coordinate of the line
Returns
const_slab_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Example:
slip::Array4d<double> A1(10,9,5,2);
slip::Array4d<double> A2(10,9,5,2);
//calculate the sums of the A1 and A2 elements pairwise for the line crossing the slabs through the first slice,
the second row and the third column. Put the calculated sums in the S array.
std::transform(A1.slab_begin(0,1,2),A1.slab_end(0,1,2),
A2.slab_begin(0,1,2),S.begin(),
std::plus<double>());
template<typename T>
slab_range_iterator slip::Array4d< T >::slab_begin ( const size_type  slice,
const size_type  row,
const size_type  col,
const slip::Range< int > &  range 
)

Returns a read/write iterator that points to the first element of the Range range of the of the line (slice,row,col) through the slabs in the Array4d. Iteration is done in ordinary element order according to the Range.

Parameters
sliceslice coordinate of the line
rowrow coordinate of the line
colcol coordinate of the line
rangeRange of the line to iterate.
Returns
begin slab_range_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Precondition
the range must be compatible with the slab dimensions
The range must be inside the whole range of the Array4d.
Example:
slip::Array4d<double> A1(8,7,6,5);
slip::Array4d<double> A2(8,7,6,5);
slip::Range<int> range(0,A1.dim2()-1,2);
//copy the the elements of the line (0,0,0) of A1 iterated according to the
//range in the line (1,1,1) of A2
std::copy(A1.slab_begin(0,0,0,range),A1.slab_end(0,0,0,range),A2.slab_begin(1,1,1));
template<typename T>
const_slab_range_iterator slip::Array4d< T >::slab_begin ( const size_type  slice,
const size_type  row,
const size_type  col,
const slip::Range< int > &  range 
) const

Returns a read only (constant) iterator that points to the first element of the Range range of the of the line (slice,row,col) through the slabs in the Array4d. Iteration is done in ordinary element order according to the Range.

Parameters
sliceslice coordinate of the line
rowrow coordinate of the line
colcol coordinate of the line
rangeRange of the line to iterate.
Returns
begin const_slab_range_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Precondition
the range must be compatible with the slab dimensions
The range must be inside the whole range of the Array4d.
Example:
slip::Array4d<double> const A1(M); //M is an already existing %Array4d
slip::Range<int> range(0,A2.dim2()-1,2);
//display the elements of the line (0,0,0) of A1 iterated according to the range
std::copy(A1.slab_begin(0,0,0,range),A1.slab_end(0,0,0,range),
std::ostream_iterator<double>(std::cout," "));
template<typename T>
slab_iterator slip::Array4d< T >::slab_end ( const size_type  slice,
const size_type  row,
const size_type  col 
)

Returns a read/write iterator that points to the one past the end element of the line (slice,row,col) through the slabs in the Array4d. Iteration is done in ordinary element order (increasing slab number).

Parameters
sliceslice coordinate of the line
rowrow coordinate of the line
colcol coordinate of the line
Returns
slab_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Example:
slip::Array4d<double> A1(10,9,5,2);
slip::Array4d<double> A2(10,9,5,2);
//calculate the sums of the A1 and A2 elements pairwise for the line crossing the slabs through the first slice,
the second row and the third column. Put the calculated sums in the S array.
std::transform(A1.slab_begin(0,1,2),A1.slab_end(0,1,2),
A2.slab_begin(0,1,2),S.begin(),
std::plus<double>());
template<typename T>
const_slab_iterator slip::Array4d< T >::slab_end ( const size_type  slice,
const size_type  row,
const size_type  col 
) const

Returns a read-only (constant) iterator that points to the one past the end element of the line (slice,row,col) through the slabs in the Array4d. Iteration is done in ordinary element order (increasing slab number).

Parameters
sliceslice coordinate of the line
rowrow coordinate of the line
colcol coordinate of the line
Returns
const_slab_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Example:
slip::Array4d<double> A1(10,9,5,2);
slip::Array4d<double> A2(10,9,5,2);
//calculate the sums of the A1 and A2 elements pairwise for the line crossing the slabs through the first slice,
the second row and the third column. Put the calculated sums in the S array.
std::transform(A1.slab_begin(0,1,2),A1.slab_end(0,1,2),
A2.slab_begin(0,1,2),S.begin(),
std::plus<double>());
template<typename T>
slab_range_iterator slip::Array4d< T >::slab_end ( const size_type  slice,
const size_type  row,
const size_type  col,
const slip::Range< int > &  range 
)

Returns a read/write iterator that points one past the end element of the Range range of the of the line (slice,row,col) through the slabs in the Array4d. Iteration is done in ordinary element order according to the Range.

Parameters
sliceslice coordinate of the line
rowrow coordinate of the line
colcol coordinate of the line
rangeRange of the line to iterate.
Returns
end slab_range_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Precondition
the range must be compatible with the slab dimensions
The range must be inside the whole range of the Array4d.
Example:
slip::Array4d<double> A1(8,7,6,5);
slip::Array4d<double> A2(8,7,6,5);
slip::Range<int> range(0,A1.dim2()-1,2);
//copy the the elements of the line (0,0,0) of A1 iterated according to the
//range in the line (1,1,1) of A2
std::copy(A1.slab_begin(0,0,0,range),A1.slab_end(0,0,0,range),A2.slab_begin(1,1,1));
template<typename T>
const_slab_range_iterator slip::Array4d< T >::slab_end ( const size_type  slice,
const size_type  row,
const size_type  col,
const slip::Range< int > &  range 
) const

Returns a read_only iterator that points one past the last element of the Range range of the of the line (slice,row,col) through the slabs in the Array4d. Iteration is done in ordinary element order according to the Range.

Parameters
sliceslice coordinate of the line
rowrow coordinate of the line
colcol coordinate of the line
rangeRange of the line to iterate.
Returns
end const_slab_range_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Precondition
the range must be compatible with the slab dimensions
The range must be inside the whole range of the Array4d.
Example:
slip::Array4d<double> const A1(M); //M is an already existing %Array4d
slip::Range<int> range(0,A2.dim2()-1,2);
//display the elements of the line (0,0,0) of A1 iterated according to the range
std::copy(A1.slab_begin(0,0,0,range),A1.slab_end(0,0,0,range),
std::ostream_iterator<double>(std::cout," "));
template<typename T>
reverse_slab_iterator slip::Array4d< T >::slab_rbegin ( const size_type  slice,
const size_type  row,
const size_type  col 
)

Returns a read/write iterator that points to the last element of the line (slice,row,col) through the slabs in the Array4d. Iteration is done in reverse element order (decreasing slab number).

Parameters
sliceslice coordinate of the line
rowrow coordinate of the line
colcol coordinate of the line
Returns
reverse_slab_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Example:
slip::Array4d<double> A1(10,9,5,2);
slip::Array4d<double> A2(10,9,5,2);
//calculate, in reverse order, the sums of the A1 and A2 elements pairwise for the line crossing
the slabs through the first slice, the second row and the third column.
Put the calculated sums in the S array.
std::transform(A1.slab_rbegin(0,1,2),A1.slab_rend(0,1,2),
A2.slab_rbegin(0,1,2),S.begin(),
std::plus<double>());
template<typename T>
const_reverse_slab_iterator slip::Array4d< T >::slab_rbegin ( const size_type  slice,
const size_type  row,
const size_type  col 
) const

Returns a read-only (constant) iterator that points to the last element of the line (slice,row,col) through the slabs in the Array4d. Iteration is done in reverse element order (decreasing slab number).

Parameters
sliceslice coordinate of the line
rowrow coordinate of the line
colcol coordinate of the line
Returns
const_reverse_slab_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Example:
slip::Array4d<double> A1(10,9,5,2);
slip::Array4d<double> A2(10,9,5,2);
//calculate, in reverse order, the sums of the A1 and A2 elements pairwise for the line crossing
the slabs through the first slice, the second row and the third column.
Put the calculated sums in the S array.
std::transform(A1.slab_rbegin(0,1,2),A1.slab_rend(0,1,2),
A2.slab_rbegin(0,1,2),S.begin(),
std::plus<double>());
template<typename T>
reverse_slab_range_iterator slip::Array4d< T >::slab_rbegin ( const size_type  slice,
const size_type  row,
const size_type  col,
const slip::Range< int > &  range 
)

Returns a read/write iterator that points to the last element of the Range range of the of the line (slice,row,col) through the slabs in the Array4d. Iteration is done in the reverse element order according to the Range.

Parameters
sliceslice coordinate of the line
rowrow coordinate of the line
colcol coordinate of the line
rangeRange of the line to iterate.
Returns
begin reverse_slab_range_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Precondition
the range must be compatible with the slab dimensions
The range must be inside the whole range of the Array4d.
Example:
slip::Array4d<double> const A1(M); //M is an already existing %Array4d
slip::Range<int> range(0,A2.dim2()-1,2);
//display the elements of the line (0,0,0) of A1 iterated in reverse order
//according to the range
std::copy(A1.slab_rbegin(0,0,0,range),A1.slab_rend(0,0,0,range),
std::ostream_iterator<double>(std::cout," "));
template<typename T>
const_reverse_slab_range_iterator slip::Array4d< T >::slab_rbegin ( const size_type  slice,
const size_type  row,
const size_type  col,
const slip::Range< int > &  range 
) const

Returns a read only (constant) iterator that points to the last element of the Range range of the of the line (slice,row,col) through the slabs in the Array4d. Iteration is done in reverse element order according to the Range.

Parameters
sliceslice coordinate of the line
rowrow coordinate of the line
colcol coordinate of the line
rangeRange of the line to iterate.
Returns
begin const_reverse_slab_range_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Precondition
the range must be compatible with the slab dimensions
The range must be inside the whole range of the Array4d.
Example:
slip::Array4d<double> const A1(M); //M is an already existing %Array4d
slip::Range<int> range(0,A2.dim2()-1,2);
//display the elements of the line (0,0,0) of A1 iterated in reverse order
//according to the range
std::copy(A1.slab_rbegin(0,0,0,range),A1.slab_rend(0,0,0,range),
std::ostream_iterator<double>(std::cout," "));
template<typename T>
reverse_slab_iterator slip::Array4d< T >::slab_rend ( const size_type  slice,
const size_type  row,
const size_type  col 
)

Returns a read/write iterator that points to the one before the first element of the line (slice,row,col) through the slabs in the Array4d. Iteration is done in reverse element order (decreasing slab number).

Parameters
sliceslice coordinate of the line
rowrow coordinate of the line
colcol coordinate of the line
Returns
reverse_slab_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Example:
slip::Array4d<double> A1(10,9,5,2);
slip::Array4d<double> A2(10,9,5,2);
//calculate, in reverse order, the sums of the A1 and A2 elements pairwise for the line crossing
the slabs through the first slice, the second row and the third column.
Put the calculated sums in the S array.
std::transform(A1.slab_rbegin(0,1,2),A1.slab_rend(0,1,2),
A2.slab_rbegin(0,1,2),S.begin(),
std::plus<double>());
template<typename T>
const_reverse_slab_iterator slip::Array4d< T >::slab_rend ( const size_type  slice,
const size_type  row,
const size_type  col 
) const

Returns a read (constant) iterator that points to the one before the first element of the line (slice,row,col) through the slabs in the Array4d. Iteration is done in reverse element order (decreasing slab number).

Parameters
sliceslice coordinate of the line
rowrow coordinate of the line
colcol coordinate of the line
Returns
const_reverse_slab_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Example:
slip::Array4d<double> A1(10,9,5,2);
slip::Array4d<double> A2(10,9,5,2);
//calculate, in reverse order, the sums of the A1 and A2 elements pairwise for the line crossing
the slabs through the first slice, the second row and the third column.
Put the calculated sums in the S array.
std::transform(A1.slab_rbegin(0,1,2),A1.slab_rend(0,1,2),
A2.slab_rbegin(0,1,2),S.begin(),
std::plus<double>());
template<typename T>
reverse_slab_range_iterator slip::Array4d< T >::slab_rend ( const size_type  slice,
const size_type  row,
const size_type  col,
const slip::Range< int > &  range 
)

Returns a read/write iterator that points to the first element of the Range range of the of the line (slice,row,col) through the slabs in the Array4d. Iteration is done in reverse element order according to the Range.

Parameters
sliceslice coordinate of the line
rowrow coordinate of the line
colcol coordinate of the line
rangeRange of the line to iterate.
Returns
end reverse_slab_range_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Precondition
the range must be compatible with the slab dimensions
The range must be inside the whole range of the Array4d.
Example:
slip::Array4d<double> const A1(M); //M is an already existing %Array4d
slip::Range<int> range(0,A2.dim2()-1,2);
//display the elements of the line (0,0,0) of A1 iterated in reverse order
//according to the range
std::copy(A1.slab_rbegin(0,0,0,range),A1.slab_rend(0,0,0,range),
std::ostream_iterator<double>(std::cout," "));
template<typename T>
const_reverse_slab_range_iterator slip::Array4d< T >::slab_rend ( const size_type  slice,
const size_type  row,
const size_type  col,
const slip::Range< int > &  range 
) const

Returns a read_only iterator that points one past the lastto the first element of the Range range of the of the line (slice,row,col) through the slabs in the Array4d. Iteration is done in reverse element order according to the Range.

Parameters
sliceslice coordinate of the line
rowrow coordinate of the line
colcol coordinate of the line
rangeRange of the line to iterate.
Returns
end const_reverse_slab_range_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Precondition
the range must be compatible with the slab dimensions
The range must be inside the whole range of the Array4d.
Example:
slip::Array4d<double> const A1(M); //M is an already existing %Array4d
slip::Range<int> range(0,A2.dim2()-1,2);
//display the elements of the line (0,0,0) of A1 iterated in reverse order
//according to the range
std::copy(A1.slab_rbegin(0,0,0,range),A1.slab_rend(0,0,0,range),
std::ostream_iterator<double>(std::cout," "));
template<typename T >
Array4d< T >::size_type slip::Array4d< T >::slabs ( ) const
inline

Returns the number of slabs (first dimension size, called time dimension too) in the Array4d.

Definition at line 4685 of file Array4d.hpp.

template<typename T>
slice_iterator slip::Array4d< T >::slice_begin ( const size_type  slab,
const size_type  row,
const size_type  col 
)

Returns a read/write iterator that points to the first element of the line (slab,row,col) through the slices in the Array4d. Iteration is done in ordinary element order (increasing slice number).

Parameters
slabslab coordinate of the line
rowrow coordinate of the line
colcol coordinate of the line
Returns
slice_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Example:
slip::Array4d<double> A1(10,9,5,2);
slip::Array4d<double> A2(10,9,5,2);
//calculate the sums of the A1 and A2 elements pairwise for the line crossing the slices through the first slab,
the second row and the third column. Put the calculated sums in the S array.
std::transform(A1.slice_begin(0,1,2),A1.slice_end(0,1,2),
A2.slice_begin(0,1,2),S.begin(),
std::plus<double>());
template<typename T>
const_slice_iterator slip::Array4d< T >::slice_begin ( const size_type  slab,
const size_type  row,
const size_type  col 
) const

Returns a read-only (constant) iterator that points to the first element of the line (slab,row,col) through the slices in the Array4d. Iteration is done in ordinary element order (increasing slice number).

Parameters
slabslab coordinate of the line
rowrow coordinate of the line
colcol coordinate of the line
Returns
const_slice_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Example:
slip::Array4d<double> A1(10,9,5,2);
slip::Array4d<double> A2(10,9,5,2);
//calculate the sums of the A1 and A2 elements pairwise for the line crossing the slices through the first slab,
the second row and the third column. Put the calculated sums in the S array.
std::transform(A1.slice_begin(0,1,2),A1.slice_end(0,1,2),
A2.slice_begin(0,1,2),S.begin(),
std::plus<double>());
template<typename T>
slice_range_iterator slip::Array4d< T >::slice_begin ( const size_type  slab,
const size_type  row,
const size_type  col,
const slip::Range< int > &  range 
)

Returns a read/write iterator that points to the first element of the Range range of the of the line (slab,row,col) through the slices in the Array4d. Iteration is done in ordinary element order according to the Range.

Parameters
slabslab coordinate of the line
rowrow coordinate of the line
colcol coordinate of the line
rangeRange of the line to iterate.
Returns
begin slice_range_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Precondition
the range must be compatible with the slice dimensions
The range must be inside the whole range of the Array4d.
Example:
slip::Array4d<double> A1(8,7,6,5);
slip::Array4d<double> A2(8,7,6,5);
slip::Range<int> range(0,A1.dim2()-1,2);
//copy the the elements of the line (0,0,0) of A1 iterated according to the
//range in the line (1,1,1) of A2
std::copy(A1.slice_begin(0,0,0,range),A1.slice_end(0,0,0,range),A2.slice_begin(1,1,1));
template<typename T>
const_slice_range_iterator slip::Array4d< T >::slice_begin ( const size_type  slab,
const size_type  row,
const size_type  col,
const slip::Range< int > &  range 
) const

Returns a read only (constant) iterator that points to the first element of the Range range of the of the line (slab,row,col) through the slices in the Array4d. Iteration is done in ordinary element order according to the Range.

Parameters
slabslab coordinate of the line
rowrow coordinate of the line
colcol coordinate of the line
rangeRange of the line to iterate.
Returns
begin const_slice_range_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Precondition
the range must be compatible with the slice dimensions
The range must be inside the whole range of the Array4d.
Example:
slip::Array4d<double> const A1(M); //M is an already existing %Array4d
slip::Range<int> range(0,A2.dim2()-1,2);
//display the elements of the line (0,0,0) of A1 iterated according to the range
std::copy(A1.slice_begin(0,0,0,range),A1.slice_end(0,0,0,range),
std::ostream_iterator<double>(std::cout," "));
template<typename T>
slice_iterator slip::Array4d< T >::slice_end ( const size_type  slab,
const size_type  row,
const size_type  col 
)

Returns a read/write iterator that points to the one past the end element of the line (slab,row,col) through the slices in the Array4d. Iteration is done in ordinary element order (increasing slice number).

Parameters
slabslab coordinate of the line
rowrow coordinate of the line
colcol coordinate of the line
Returns
slice_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Example:
slip::Array4d<double> A1(10,9,5,2);
slip::Array4d<double> A2(10,9,5,2);
//calculate the sums of the A1 and A2 elements pairwise for the line crossing the slices through the first slab,
the second row and the third column. Put the calculated sums in the S array.
std::transform(A1.slice_begin(0,1,2),A1.slice_end(0,1,2),
A2.slice_begin(0,1,2),S.begin(),
std::plus<double>());
template<typename T>
const_slice_iterator slip::Array4d< T >::slice_end ( const size_type  slab,
const size_type  row,
const size_type  col 
) const

Returns a read-only (constant) iterator that points to the one past the end element of the line (slab,row,col) through the slices in the Array4d. Iteration is done in ordinary element order (increasing slice number).

Parameters
slabslab coordinate of the line
rowrow coordinate of the line
colcol coordinate of the line
Returns
const_slice_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Example:
slip::Array4d<double> A1(10,9,5,2);
slip::Array4d<double> A2(10,9,5,2);
//calculate the sums of the A1 and A2 elements pairwise for the line crossing the slices through the first slab,
the second row and the third column. Put the calculated sums in the S array.
std::transform(A1.slice_begin(0,1,2),A1.slice_end(0,1,2),
A2.slice_begin(0,1,2),S.begin(),
std::plus<double>());
template<typename T>
slice_range_iterator slip::Array4d< T >::slice_end ( const size_type  slab,
const size_type  row,
const size_type  col,
const slip::Range< int > &  range 
)

Returns a read/write iterator that points one past the end element of the Range range of the of the line (slab,row,col) through the slices in the Array4d. Iteration is done in ordinary element order according to the Range.

Parameters
slabslab coordinate of the line
rowrow coordinate of the line
colcol coordinate of the line
rangeRange of the line to iterate.
Returns
end slice_range_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Precondition
the range must be compatible with the slice dimensions
The range must be inside the whole range of the Array4d.
Example:
slip::Array4d<double> A1(8,7,6,5);
slip::Array4d<double> A2(8,7,6,5);
slip::Range<int> range(0,A1.dim2()-1,2);
//copy the the elements of the line (0,0,0) of A1 iterated according to the
//range in the line (1,1,1) of A2
std::copy(A1.slice_begin(0,0,0,range),A1.slice_end(0,0,0,range),A2.slice_begin(1,1,1));
template<typename T>
const_slice_range_iterator slip::Array4d< T >::slice_end ( const size_type  slab,
const size_type  row,
const size_type  col,
const slip::Range< int > &  range 
) const

Returns a read_only iterator that points one past the last element of the Range range of the of the line (slab,row,col) through the slices in the Array4d. Iteration is done in ordinary element order according to the Range.

Parameters
slabslab coordinate of the line
rowrow coordinate of the line
colcol coordinate of the line
rangeRange of the line to iterate.
Returns
end const_slice_range_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Precondition
the range must be compatible with the slice dimensions
The range must be inside the whole range of the Array4d.
Example:
slip::Array4d<double> const A1(M); //M is an already existing %Array4d
slip::Range<int> range(0,A2.dim2()-1,2);
//display the elements of the line (0,0,0) of A1 iterated according to the range
std::copy(A1.slice_begin(0,0,0,range),A1.slice_end(0,0,0,range),
std::ostream_iterator<double>(std::cout," "));
template<typename T>
reverse_slice_iterator slip::Array4d< T >::slice_rbegin ( const size_type  slab,
const size_type  row,
const size_type  col 
)

Returns a read/write iterator that points to the last element of the line (slab,row,col) through the slices in the Array4d. Iteration is done in reverse element order (decreasing slice number).

Parameters
slabslab coordinate of the line
rowrow coordinate of the line
colcol coordinate of the line
Returns
reverse_slice_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Example:
slip::Array4d<double> A1(10,9,5,2);
slip::Array4d<double> A2(10,9,5,2);
//calculate, in reverse order, the sums of the A1 and A2 elements pairwise for the line crossing
the slices through the first slab, the second row and the third column.
Put the calculated sums in the S array.
std::transform(A1.slice_rbegin(0,1,2),A1.slice_rend(0,1,2),
A2.slice_rbegin(0,1,2),S.begin(),
std::plus<double>());
template<typename T>
const_reverse_slice_iterator slip::Array4d< T >::slice_rbegin ( const size_type  slab,
const size_type  row,
const size_type  col 
) const

Returns a read-only (constant) iterator that points to the last element of the line (slab,row,col) through the slices in the Array4d. Iteration is done in reverse element order (decreasing slice number).

Parameters
slabslab coordinate of the line
rowrow coordinate of the line
colcol coordinate of the line
Returns
const_reverse_slice_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Example:
slip::Array4d<double> A1(10,9,5,2);
slip::Array4d<double> A2(10,9,5,2);
//calculate, in reverse order, the sums of the A1 and A2 elements pairwise for the line crossing
the slices through the first slab, the second row and the third column.
Put the calculated sums in the S array.
std::transform(A1.slice_rbegin(0,1,2),A1.slice_rend(0,1,2),
A2.slice_rbegin(0,1,2),S.begin(),
std::plus<double>());
template<typename T>
reverse_slice_range_iterator slip::Array4d< T >::slice_rbegin ( const size_type  slab,
const size_type  row,
const size_type  col,
const slip::Range< int > &  range 
)

Returns a read/write iterator that points to the last element of the Range range of the of the line (slab,row,col) through the slices in the Array4d. Iteration is done in the reverse element order according to the Range.

Parameters
slabslab coordinate of the line
rowrow coordinate of the line
colcol coordinate of the line
rangeRange of the line to iterate.
Returns
begin reverse_slice_range_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Precondition
the range must be compatible with the slice dimensions
The range must be inside the whole range of the Array4d.
Example:
slip::Array4d<double> const A1(M); //M is an already existing %Array4d
slip::Range<int> range(0,A2.dim2()-1,2);
//display the elements of the line (0,0,0) of A1 iterated in reverse order
//according to the range
std::copy(A1.slice_rbegin(0,0,0,range),A1.slice_rend(0,0,0,range),
std::ostream_iterator<double>(std::cout," "));
template<typename T>
const_reverse_slice_range_iterator slip::Array4d< T >::slice_rbegin ( const size_type  slab,
const size_type  row,
const size_type  col,
const slip::Range< int > &  range 
) const

Returns a read only (constant) iterator that points to the last element of the Range range of the of the line (slab,row,col) through the slices in the Array4d. Iteration is done in reverse element order according to the Range.

Parameters
slabslab coordinate of the line
rowrow coordinate of the line
colcol coordinate of the line
rangeRange of the line to iterate.
Returns
begin const_reverse_slice_range_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Precondition
the range must be compatible with the slice dimensions
The range must be inside the whole range of the Array4d.
Example:
slip::Array4d<double> const A1(M); //M is an already existing %Array4d
slip::Range<int> range(0,A2.dim2()-1,2);
//display the elements of the line (0,0,0) of A1 iterated in reverse order
//according to the range
std::copy(A1.slice_rbegin(0,0,0,range),A1.slice_rend(0,0,0,range),
std::ostream_iterator<double>(std::cout," "));
template<typename T>
reverse_slice_iterator slip::Array4d< T >::slice_rend ( const size_type  slab,
const size_type  row,
const size_type  col 
)

Returns a read/write iterator that points to the one before the first element of the line (slab,row,col) through the slices in the Array4d. Iteration is done in reverse element order (decreasing slice number).

Parameters
slabslab coordinate of the line
rowrow coordinate of the line
colcol coordinate of the line
Returns
reverse_slice_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Example:
slip::Array4d<double> A1(10,9,5,2);
slip::Array4d<double> A2(10,9,5,2);
//calculate, in reverse order, the sums of the A1 and A2 elements pairwise for the line crossing
the slices through the first slab, the second row and the third column.
Put the calculated sums in the S array.
std::transform(A1.slice_rbegin(0,1,2),A1.slice_rend(0,1,2),
A2.slice_rbegin(0,1,2),S.begin(),
std::plus<double>());
template<typename T>
const_reverse_slice_iterator slip::Array4d< T >::slice_rend ( const size_type  slab,
const size_type  row,
const size_type  col 
) const

Returns a read (constant) iterator that points to the one before the first element of the line (slab,row,col) through the slices in the Array4d. Iteration is done in reverse element order (decreasing slice number).

Parameters
slabslab coordinate of the line
rowrow coordinate of the line
colcol coordinate of the line
Returns
const_reverse_slice_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Example:
slip::Array4d<double> A1(10,9,5,2);
slip::Array4d<double> A2(10,9,5,2);
//calculate, in reverse order, the sums of the A1 and A2 elements pairwise for the line crossing
the slices through the first slab, the second row and the third column.
Put the calculated sums in the S array.
std::transform(A1.slice_rbegin(0,1,2),A1.slice_rend(0,1,2),
A2.slice_rbegin(0,1,2),S.begin(),
std::plus<double>());
template<typename T>
reverse_slice_range_iterator slip::Array4d< T >::slice_rend ( const size_type  slab,
const size_type  row,
const size_type  col,
const slip::Range< int > &  range 
)

Returns a read/write iterator that points to the first element of the Range range of the of the line (slab,row,col) through the slices in the Array4d. Iteration is done in reverse element order according to the Range.

Parameters
slabslab coordinate of the line
rowrow coordinate of the line
colcol coordinate of the line
rangeRange of the line to iterate.
Returns
end reverse_slice_range_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Precondition
the range must be compatible with the slice dimensions
The range must be inside the whole range of the Array4d.
Example:
slip::Array4d<double> const A1(M); //M is an already existing %Array4d
slip::Range<int> range(0,A2.dim2()-1,2);
//display the elements of the line (0,0,0) of A1 iterated in reverse order
//according to the range
std::copy(A1.slice_rbegin(0,0,0,range),A1.slice_rend(0,0,0,range),
std::ostream_iterator<double>(std::cout," "));
template<typename T>
const_reverse_slice_range_iterator slip::Array4d< T >::slice_rend ( const size_type  slab,
const size_type  row,
const size_type  col,
const slip::Range< int > &  range 
) const

Returns a read_only iterator that points one past the lastto the first element of the Range range of the of the line (slab,row,col) through the slices in the Array4d. Iteration is done in reverse element order according to the Range.

Parameters
slabslab coordinate of the line
rowrow coordinate of the line
colcol coordinate of the line
rangeRange of the line to iterate.
Returns
end const_reverse_slice_range_iterator value
Remarks
This iterator is compatible with RandomAccessIterator algorithms.
Precondition
the range must be compatible with the slice dimensions
The range must be inside the whole range of the Array4d.
Example:
slip::Array4d<double> const A1(M); //M is an already existing %Array4d
slip::Range<int> range(0,A2.dim2()-1,2);
//display the elements of the line (0,0,0) of A1 iterated in reverse order
//according to the range
std::copy(A1.slice_rbegin(0,0,0,range),A1.slice_rend(0,0,0,range),
std::ostream_iterator<double>(std::cout," "));
template<typename T >
Array4d< T >::size_type slip::Array4d< T >::slices ( ) const
inline

Returns the number of slices (second dimension size) in the Array4d.

Definition at line 4695 of file Array4d.hpp.

template<typename T >
void slip::Array4d< T >::swap ( Array4d< T > &  M)
inline

Swaps data with another Array4d.

Parameters
MA Array4d of the same element type
Precondition
dim1() == M.dim1()
dim2() == M.dim2()
dim3() == M.dim3()
dim4() == M.dim4()

Definition at line 4742 of file Array4d.hpp.

Friends And Related Function Documentation

template<typename T>
friend class boost::serialization::access
friend

Definition at line 3193 of file Array4d.hpp.

template<typename T>
bool operator!= ( const Array4d< T > &  x,
const Array4d< T > &  y 
)
friend

Array4d inequality comparison

Parameters
xA Array4d
yA Array4d of the same type of x
Returns
true if !(x == y)

Definition at line 4768 of file Array4d.hpp.

template<typename T>
bool operator< ( const Array4d< T > &  x,
const Array4d< T > &  y 
)
friend

Less than comparison operator (Array4d ordering relation)

Parameters
xA Array4d
yA Array4d of the same type of x
Returns
true iff x is lexicographically less than y

Definition at line 4778 of file Array4d.hpp.

template<typename T>
std::ostream& operator<< ( std::ostream &  out,
const self a 
)
friend

Write the Array4d to the ouput stream.

Parameters
outoutput std::ostream
aArray4d to write to the output stream

Definition at line 4592 of file Array4d.hpp.

template<typename T>
bool operator<= ( const Array4d< T > &  x,
const Array4d< T > &  y 
)
friend

Less than equal comparison operator.

Parameters
xA Array4d
yA Array4d of the same type of x
Returns
true iff !(y > x)

Definition at line 4796 of file Array4d.hpp.

template<typename T>
bool operator== ( const Array4d< T > &  x,
const Array4d< T > &  y 
)
friend

Array4d equality comparison

Parameters
xA Array4d
yA Array4d of the same type of x
Returns
true iff the size and the elements of the Arrays are equal

Definition at line 4759 of file Array4d.hpp.

template<typename T>
bool operator> ( const Array4d< T > &  x,
const Array4d< T > &  y 
)
friend

More than comparison operator.

Parameters
xA Array4d
yA Array4d of the same type of x
Returns
true iff y > x

Definition at line 4788 of file Array4d.hpp.

template<typename T>
bool operator>= ( const Array4d< T > &  x,
const Array4d< T > &  y 
)
friend

More than equal comparison operator.

Parameters
xA Array4d
yA Array4d of the same type of x
Returns
true iff !(x < y)

Definition at line 4804 of file Array4d.hpp.

Member Data Documentation

template<typename T>
const std::size_t slip::Array4d< T >::DIM = 4
static

Definition at line 237 of file Array4d.hpp.


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