blitz  Version 1.0.2
blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype > Class Template Reference

#include <tm2fastiter.h>

Inheritance diagram for blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >:
Inheritance graph
Collaboration diagram for blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >:
Collaboration graph

Classes

class  SliceInfo
 
struct  tvresult
 For an iterator, the vectorized result for width N is always a TinyVector<T_numtype, N>. More...
 

Public Types

typedef P_numtype T_numtype
 
typedef opType< T_numtype >::T_optype T_optype
 
typedef asET< T_numtype >::T_wrapped T_typeprop
 
typedef unwrapET< T_typeprop >::T_unwrapped T_result
 
typedef ETBase< FastTV2Iterator< T_numtype, simdTypes< T_numtype >::vecWidth > > T_tvtypeprop
 Result type for fastRead_tv is a FastTVIterator. More...
 
typedef unwrapET< T_tvtypeprop >::T_unwrapped T_tvresult
 
typedef TinyMatrix< T_numtype, N_rows, N_columns > T_matrix
 
typedef FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype > T_iterator
 
typedef const T_matrixT_ctorArg1
 
typedef int T_ctorArg2
 
typedef FastTM2CopyIterator< P_numtype, N_rows, N_columns > T_range_result
 

Public Member Functions

 FastTM2IteratorBase (const T_iterator &x)
 
void operator= (const T_iterator &x)
 
 FastTM2IteratorBase (const T_matrix &array)
 
 ~FastTM2IteratorBase ()
 
T_result operator() (TinyVector< int, 2 > i) const
 
T_result first_value () const
 
T_result operator* () const
 
T_result operator[] (int i) const
 
T_result fastRead (diffType i) const
 
template<int N>
tvresult< N >::Type fastRead_tv (diffType i) const
 
bool isVectorAligned (diffType offset) const
 Since data_ is simd aligned by construction, we just have to check the offest. More...
 
void push (int position)
 
void pop (int position)
 
void advance ()
 
void advance (int n)
 
void loadStride (int rank)
 
const T_numtype *restrict data () const
 
const T_matrixarray () const
 
void _bz_setData (const T_numtype *ptr)
 
void _bz_offsetData (sizeType i)
 
void _bz_offsetData (sizeType offset, int dim)
 
void _bz_offsetData (sizeType offset1, int dim1, sizeType offset2, int dim2)
 
int stride () const
 
bool isUnitStride () const
 
void advanceUnitStride ()
 
bool canCollapse (int outerLoopRank, int innerLoopRank) const
 
template<typename T_shape >
bool shapeCheck (const T_shape &s) const
 
T_result shift (int offset, int dim) const
 
T_result shift (int offset1, int dim1, int offset2, int dim2) const
 
void prettyPrint (std::string &str, prettyPrintFormat &format) const
 

Static Public Member Functions

static int ascending (const int r)
 
static int ordering (const int r)
 
static int lbound (const int r)
 
static int ubound (const int r)
 
static int suggestStride (int r)
 
static bool isStride (int r, diffType stride)
 
static bool isUnitStride (int r)
 

Static Public Attributes

static const int numArrayOperands = 0
 
static const int numTVOperands = 0
 
static const int numTMOperands = 1
 
static const int numIndexPlaceholders = 0
 
static const int minWidth = simdTypes<T_numtype>::vecWidth
 
static const int maxWidth = simdTypes<T_numtype>::vecWidth
 
static const int rank_ = 2
 

Protected Attributes

const T_numtype *restrict data_
 
P_arraytype array_
 
ConstPointerStack< T_numtype, rank_stack_
 
diffType stride_
 

Member Typedef Documentation

template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
typedef const T_matrix& blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::T_ctorArg1
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
typedef int blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::T_ctorArg2
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
typedef FastTM2IteratorBase<P_numtype, N_rows, N_columns, P_arraytype> blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::T_iterator
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
typedef TinyMatrix<T_numtype, N_rows, N_columns> blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::T_matrix
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
typedef P_numtype blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::T_numtype
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
typedef opType<T_numtype>::T_optype blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::T_optype
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
typedef FastTM2CopyIterator<P_numtype, N_rows, N_columns> blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::T_range_result
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
typedef unwrapET<T_typeprop>::T_unwrapped blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::T_result
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
typedef unwrapET<T_tvtypeprop>::T_unwrapped blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::T_tvresult
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
typedef ETBase<FastTV2Iterator<T_numtype, simdTypes<T_numtype>::vecWidth> > blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::T_tvtypeprop

Result type for fastRead_tv is a FastTVIterator.

This should only be used for mixed TM/Array expressions.

template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
typedef asET<T_numtype>::T_wrapped blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::T_typeprop

Constructor & Destructor Documentation

template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::FastTM2IteratorBase ( const T_iterator x)
inline
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::FastTM2IteratorBase ( const T_matrix array)
inline
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::~FastTM2IteratorBase ( )
inline

Member Function Documentation

template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
void blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::_bz_offsetData ( sizeType  i)
inline
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
void blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::_bz_offsetData ( sizeType  offset,
int  dim 
)
inline
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
void blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::_bz_offsetData ( sizeType  offset1,
int  dim1,
sizeType  offset2,
int  dim2 
)
inline
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
void blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::_bz_setData ( const T_numtype ptr)
inline
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
void blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::advance ( )
inline
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
void blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::advance ( int  n)
inline
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
void blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::advanceUnitStride ( )
inline
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
const T_matrix& blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::array ( ) const
inline
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
static int blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::ascending ( const int  r)
inlinestatic
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
bool blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::canCollapse ( int  outerLoopRank,
int  innerLoopRank 
) const
inline
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
const T_numtype* restrict blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::data ( ) const
inline
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
T_result blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::fastRead ( diffType  i) const
inline
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
template<int N>
tvresult<N>::Type blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::fastRead_tv ( diffType  i) const
inline
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
T_result blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::first_value ( ) const
inline
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
static bool blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::isStride ( int  r,
diffType  stride 
)
inlinestatic
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
static bool blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::isUnitStride ( int  r)
inlinestatic
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
bool blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::isUnitStride ( ) const
inline
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
bool blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::isVectorAligned ( diffType  offset) const
inline

Since data_ is simd aligned by construction, we just have to check the offest.

template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
static int blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::lbound ( const int  r)
inlinestatic
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
void blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::loadStride ( int  rank)
inline
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
T_result blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::operator() ( TinyVector< int, 2 >  i) const
inline
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
T_result blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::operator* ( ) const
inline
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
void blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::operator= ( const T_iterator x)
inline
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
T_result blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::operator[] ( int  i) const
inline
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
static int blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::ordering ( const int  r)
inlinestatic
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
void blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::pop ( int  position)
inline
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
void blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::prettyPrint ( std::string &  str,
prettyPrintFormat format 
) const
inline
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
void blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::push ( int  position)
inline
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
template<typename T_shape >
bool blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::shapeCheck ( const T_shape &  s) const
inline
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
T_result blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::shift ( int  offset,
int  dim 
) const
inline
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
T_result blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::shift ( int  offset1,
int  dim1,
int  offset2,
int  dim2 
) const
inline
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
static int blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::suggestStride ( int  r)
inlinestatic
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
static int blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::ubound ( const int  r)
inlinestatic

Member Data Documentation

template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
const T_numtype* restrict blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::data_
protected

Referenced by blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, const TinyMatrix< P_numtype, N_rows, N_columns > & >::_bz_offsetData(), blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, const TinyMatrix< P_numtype, N_rows, N_columns > & >::_bz_setData(), blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, const TinyMatrix< P_numtype, N_rows, N_columns > & >::advance(), blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, const TinyMatrix< P_numtype, N_rows, N_columns > & >::advanceUnitStride(), blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, const TinyMatrix< P_numtype, N_rows, N_columns > & >::data(), blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, const TinyMatrix< P_numtype, N_rows, N_columns > & >::fastRead_tv(), blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, const TinyMatrix< P_numtype, N_rows, N_columns > & >::FastTM2IteratorBase(), blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, const TinyMatrix< P_numtype, N_rows, N_columns > & >::first_value(), blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, const TinyMatrix< P_numtype, N_rows, N_columns > & >::operator*(), blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, const TinyMatrix< P_numtype, N_rows, N_columns > & >::operator=(), blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, const TinyMatrix< P_numtype, N_rows, N_columns > & >::operator[](), blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, const TinyMatrix< P_numtype, N_rows, N_columns > & >::pop(), blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, const TinyMatrix< P_numtype, N_rows, N_columns > & >::push(), and blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, const TinyMatrix< P_numtype, N_rows, N_columns > & >::shift().

template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
const int blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::maxWidth = simdTypes<T_numtype>::vecWidth
static
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
const int blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::minWidth = simdTypes<T_numtype>::vecWidth
static
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
const int blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::numArrayOperands = 0
static
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
const int blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::numIndexPlaceholders = 0
static
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
const int blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::numTMOperands = 1
static
template<typename P_numtype, int N_rows, int N_columns, typename P_arraytype>
const int blitz::FastTM2IteratorBase< P_numtype, N_rows, N_columns, P_arraytype >::numTVOperands = 0
static

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