|
shards
Version of the Day
|
The multi-dimensional Array interface with runtime user-defined dimension ordinates. Typically used when runtime-polymorphic arrays are passed to functions. More...
#include <Shards_Array.hpp>
Public Member Functions | |
| template<class Tag1 , class Tag2 , class Tag3 , class Tag4 , class Tag5 , class Tag6 , class Tag7 , class Tag8 > | |
| Array & | assign (value_type *ptr, size_type n1, size_type n2, size_type n3, size_type n4, size_type n5, size_type n6, size_type n7, size_type n8) |
| template<class Tag1 , class Tag2 , class Tag3 , class Tag4 , class Tag5 , class Tag6 , class Tag7 > | |
| Array & | assign (value_type *ptr, size_type n1, size_type n2, size_type n3, size_type n4, size_type n5, size_type n6, size_type n7) |
| template<class Tag1 , class Tag2 , class Tag3 , class Tag4 , class Tag5 , class Tag6 > | |
| Array & | assign (value_type *ptr, size_type n1, size_type n2, size_type n3, size_type n4, size_type n5, size_type n6) |
| template<class Tag1 , class Tag2 , class Tag3 , class Tag4 , class Tag5 > | |
| Array & | assign (value_type *ptr, size_type n1, size_type n2, size_type n3, size_type n4, size_type n5) |
| template<class Tag1 , class Tag2 , class Tag3 , class Tag4 > | |
| Array & | assign (value_type *ptr, size_type n1, size_type n2, size_type n3, size_type n4) |
| template<class Tag1 , class Tag2 , class Tag3 > | |
| Array & | assign (value_type *ptr, size_type n1, size_type n2, size_type n3) |
| template<class Tag1 , class Tag2 > | |
| Array & | assign (value_type *ptr, size_type n1, size_type n2) |
| template<class Tag1 > | |
| Array & | assign (value_type *ptr, size_type n1) |
Friends | |
| class | shards::Array |
Array Attributes | |
| enum | { Natural = NaturalOrder == array_order } |
| If the multidimension follows the natural ordering. | |
| enum | { Reverse = FortranOrder == array_order } |
| If the multidimension follows the reverse (Fortran) ordering. | |
| enum | { Contiguous = true } |
| If the member data storage is contiguous. | |
| typedef Scalar | value_type |
| Type of member data. | |
| typedef array_traits::int_t | size_type |
| Type for sizes. | |
| typedef const ArrayDimTag * | tag_type |
| Type of runtime dimension tags. | |
| size_type | rank () const |
| Rank of the array is the number of non-void dimension tags. | |
| bool | natural () const |
| If the multidimension follows the natural ordering. | |
| bool | reverse () const |
| If the multidimension follows the reverse (Fortran) ordering. | |
| bool | contiguous () const |
| If the member data storage is contiguous. | |
| tag_type | tag (size_type ord) const |
| Access the dimension tag-singleton for a given ordinate. | |
| size_type | dimension (size_type ord) const |
| Dimension of the given ordinate. | |
| template<typename iType > | |
| void | dimensions (std::vector< iType > &n) |
| Dimension of all ordinate. | |
| size_type | size () const |
| Total number of data items. | |
Member data access operators | |
| template<typename iType > | |
| Array | truncate (const iType &i) const |
| Generate a subarray view of the array with the slowest striding ordinate offset by i and removed. | |
| value_type * | contiguous_data () const |
| Pointer to contiguous block of member data. | |
| template<typename iType > | |
| value_type & | operator[] (const iType &i) const |
| Access member via full ordering of members. | |
| template<typename iType > | |
| value_type & | operator() (const iType &i1, const iType &i2, const iType &i3, const iType &i4, const iType &i5, const iType &i6, const iType &i7, const iType &i8) const |
| Access member via Rank 8 multi-index. | |
| template<typename iType > | |
| value_type & | operator() (const iType &i1, const iType &i2, const iType &i3, const iType &i4, const iType &i5, const iType &i6, const iType &i7) const |
| template<typename iType > | |
| value_type & | operator() (const iType &i1, const iType &i2, const iType &i3, const iType &i4, const iType &i5, const iType &i6) const |
| template<typename iType > | |
| value_type & | operator() (const iType &i1, const iType &i2, const iType &i3, const iType &i4, const iType &i5) const |
| template<typename iType > | |
| value_type & | operator() (const iType &i1, const iType &i2, const iType &i3, const iType &i4) const |
| template<typename iType > | |
| value_type & | operator() (const iType &i1, const iType &i2, const iType &i3) const |
| template<typename iType > | |
| value_type & | operator() (const iType &i1, const iType &i2) const |
| template<typename iType > | |
| value_type & | operator() (const iType &i1) const |
Constructors and Assignment Operators | |
|
typedef array_traits::Helper < Scalar, array_order, void, void, void, void, void, void, void, void >::reverse | ReverseType |
| Array () | |
| Array (const Array &rhs) | |
| Array & | operator= (const Array &rhs) |
| Array (const ReverseType &rhs) | |
| Copy constructor for reverse type. | |
| Array & | operator= (const ReverseType &rhs) |
| Assignment operator for reverse type. | |
| Array (value_type *ptr, const size_type input_rank, const size_type *const dims, const tag_type *const tags) | |
The multi-dimensional Array interface with runtime user-defined dimension ordinates. Typically used when runtime-polymorphic arrays are passed to functions.
| Scalar | The "plain old data" type of the array's member data. |
| array_order | An ArrayOrder value that specifies whether to use Natural (a.k.a. C-language) or Fortran ordering for the multi-dimensions and multi-indices. |
Definition at line 3194 of file Shards_Array.hpp.