Classes | Public Types | Public Member Functions | Private Types | Private Member Functions | Private Attributes | List of all members
blaze::DVecDVecMapExpr< VT1, VT2, OP, TF > Class Template Reference

Expression object for the dense vector-dense vector map() function.The DVecDVecMapExpr class represents the compile time expression for the pairwise evaluation of a binary custom operation on the elements of two dense vectors via the map() function. More...

#include <DVecDVecMapExpr.h>

Inherits blaze::VecVecMapExpr< DenseVector< DVecDVecMapExpr< VT1, VT2, OP, TF >, TF > >, and blaze::Computation.

Classes

class  ConstIterator
 Iterator over the elements of the dense vector map expression. More...
 

Public Types

enum  : bool { simdEnabled }
 Compilation switch for the expression template evaluation strategy.
 
enum  : bool { smpAssignable = VT1::smpAssignable && VT2::smpAssignable }
 Compilation switch for the expression template assignment strategy.
 
enum  : size_t { SIMDSIZE = SIMDTrait<ElementType>::size }
 The number of elements packed within a single SIMD element.
 
using This = DVecDVecMapExpr< VT1, VT2, OP, TF >
 Type of this DVecDVecMapExpr instance.
 
using ResultType = BinaryMapTrait_< RT1, RT2, OP >
 Result type for expression template evaluations.
 
using TransposeType = TransposeType_< ResultType >
 Transpose type for expression template evaluations.
 
using ElementType = ElementType_< ResultType >
 Resulting element type.
 
using ReturnType = decltype(std::declval< OP >()(std::declval< RN1 >(), std::declval< RN2 >()))
 Return type for expression template evaluations.
 
using CompositeType = IfTrue_< useAssign, const ResultType, const DVecDVecMapExpr &>
 Data type for composite expression templates.
 
using LeftOperand = If_< IsExpression< VT1 >, const VT1, const VT1 &>
 Composite type of the left-hand side dense vector expression.
 
using RightOperand = If_< IsExpression< VT2 >, const VT2, const VT2 &>
 Composite type of the right-hand side dense vector expression.
 
using Operation = OP
 Data type of the custom unary operation.
 
using LT = If_< RequiresEvaluation< VT1 >, const RT1, CT1 >
 Type for the assignment of the left-hand side dense vector operand.
 
using RT = If_< RequiresEvaluation< VT2 >, const RT2, CT2 >
 Type for the assignment of the right-hand side dense vector operand.
 
using VectorType = VT
 Type of the vector.
 

Public Member Functions

 DVecDVecMapExpr (const VT1 &lhs, const VT2 &rhs, OP op) noexcept
 Constructor for the DVecMapExpr class. More...
 
ReturnType operator[] (size_t index) const
 Subscript operator for the direct access to the vector elements. More...
 
ReturnType at (size_t index) const
 Checked access to the vector elements. More...
 
BLAZE_ALWAYS_INLINE auto load (size_t index) const noexcept
 Access to the SIMD elements of the vector. More...
 
ConstIterator begin () const
 Returns an iterator to the first non-zero element of the dense vector. More...
 
ConstIterator end () const
 Returns an iterator just past the last non-zero element of the dense vector. More...
 
size_t size () const noexcept
 Returns the current size/dimension of the vector. More...
 
LeftOperand leftOperand () const noexcept
 Returns the left-hand side dense vector operand. More...
 
RightOperand rightOperand () const noexcept
 Returns the right-hand side dense vector operand. More...
 
Operation operation () const
 Returns a copy of the custom operation. More...
 
template<typename T >
bool canAlias (const T *alias) const noexcept
 Returns whether the expression can alias with the given address alias. More...
 
template<typename T >
bool isAliased (const T *alias) const noexcept
 Returns whether the expression is aliased with the given address alias. More...
 
bool isAligned () const noexcept
 Returns whether the operands of the expression are properly aligned in memory. More...
 
bool canSMPAssign () const noexcept
 Returns whether the expression can be used in SMP assignments. More...
 
BLAZE_ALWAYS_INLINE VectorTypeoperator~ () noexcept
 Conversion operator for non-constant vectors. More...
 
BLAZE_ALWAYS_INLINE const VectorTypeoperator~ () const noexcept
 Conversion operator for constant vectors. More...
 

Private Types

enum  : bool { useAssign = ( RequiresEvaluation<VT1>::value || RequiresEvaluation<VT2>::value ) }
 Compilation switch for the serial evaluation strategy of the map expression. More...
 
using RT1 = ResultType_< VT1 >
 Result type of the left-hand side dense vector expression.
 
using RT2 = ResultType_< VT2 >
 Result type of the right-hand side dense vector expression.
 
using ET1 = ElementType_< VT1 >
 Element type of the left-hand side dense vector expression.
 
using ET2 = ElementType_< VT2 >
 Element type of the right-hand side dense vector expression.
 
using RN1 = ReturnType_< VT1 >
 Return type of the left-hand side dense vector expression.
 
using RN2 = ReturnType_< VT2 >
 Return type of the right-hand side dense vector expression.
 
using CT1 = CompositeType_< VT1 >
 Composite type of the left-hand side dense vector expression.
 
using CT2 = CompositeType_< VT2 >
 Composite type of the right-hand side dense vector expression.
 

Private Member Functions

 BLAZE_CREATE_HAS_DATA_OR_FUNCTION_MEMBER_TYPE_TRAIT (HasSIMDEnabled, simdEnabled)
 Definition of the HasSIMDEnabled type trait.
 
 BLAZE_CREATE_HAS_DATA_OR_FUNCTION_MEMBER_TYPE_TRAIT (HasLoad, load)
 Definition of the HasLoad type trait.
 

Private Attributes

LeftOperand lhs_
 Left-hand side dense vector of the map expression.
 
RightOperand rhs_
 Right-hand side dense vector of the map expression.
 
Operation op_
 The custom unary operation.
 

Detailed Description

template<typename VT1, typename VT2, typename OP, bool TF>
class blaze::DVecDVecMapExpr< VT1, VT2, OP, TF >

Expression object for the dense vector-dense vector map() function.

The DVecDVecMapExpr class represents the compile time expression for the pairwise evaluation of a binary custom operation on the elements of two dense vectors via the map() function.

Member Enumeration Documentation

◆ anonymous enum

template<typename VT1 , typename VT2 , typename OP , bool TF>
anonymous enum : bool
private

Compilation switch for the serial evaluation strategy of the map expression.

The useAssign compile time constant expression represents a compilation switch for the serial evaluation strategy of the map expression. In case either of the two dense vector operands requires an intermediate evaluation, useAssign will be set to 1 and the addition expression will be evaluated via the assign function family. Otherwise useAssign will be set to 0 and the expression will be evaluated via the subscript operator.

Constructor & Destructor Documentation

◆ DVecDVecMapExpr()

template<typename VT1 , typename VT2 , typename OP , bool TF>
blaze::DVecDVecMapExpr< VT1, VT2, OP, TF >::DVecDVecMapExpr ( const VT1 &  lhs,
const VT2 &  rhs,
OP  op 
)
inlineexplicitnoexcept

Constructor for the DVecMapExpr class.

Parameters
lhsThe left-hand side dense vector operand of the map expression.
rhsThe right-hand side dense vector operand of the map expression.
opThe custom unary operation.

Member Function Documentation

◆ at()

template<typename VT1 , typename VT2 , typename OP , bool TF>
ReturnType blaze::DVecDVecMapExpr< VT1, VT2, OP, TF >::at ( size_t  index) const
inline

Checked access to the vector elements.

Parameters
indexAccess index. The index has to be in the range $[0..N-1]$.
Returns
The resulting value.
Exceptions
std::out_of_rangeInvalid vector access index.

◆ begin()

template<typename VT1 , typename VT2 , typename OP , bool TF>
ConstIterator blaze::DVecDVecMapExpr< VT1, VT2, OP, TF >::begin ( ) const
inline

Returns an iterator to the first non-zero element of the dense vector.

Returns
Iterator to the first non-zero element of the dense vector.

◆ canAlias()

template<typename VT1 , typename VT2 , typename OP , bool TF>
template<typename T >
bool blaze::DVecDVecMapExpr< VT1, VT2, OP, TF >::canAlias ( const T *  alias) const
inlinenoexcept

Returns whether the expression can alias with the given address alias.

Parameters
aliasThe alias to be checked.
Returns
true in case the expression can alias, false otherwise.

◆ canSMPAssign()

template<typename VT1 , typename VT2 , typename OP , bool TF>
bool blaze::DVecDVecMapExpr< VT1, VT2, OP, TF >::canSMPAssign ( ) const
inlinenoexcept

Returns whether the expression can be used in SMP assignments.

Returns
true in case the expression can be used in SMP assignments, false if not.

◆ end()

template<typename VT1 , typename VT2 , typename OP , bool TF>
ConstIterator blaze::DVecDVecMapExpr< VT1, VT2, OP, TF >::end ( ) const
inline

Returns an iterator just past the last non-zero element of the dense vector.

Returns
Iterator just past the last non-zero element of the dense vector.

◆ isAliased()

template<typename VT1 , typename VT2 , typename OP , bool TF>
template<typename T >
bool blaze::DVecDVecMapExpr< VT1, VT2, OP, TF >::isAliased ( const T *  alias) const
inlinenoexcept

Returns whether the expression is aliased with the given address alias.

Parameters
aliasThe alias to be checked.
Returns
true in case an alias effect is detected, false otherwise.

◆ isAligned()

template<typename VT1 , typename VT2 , typename OP , bool TF>
bool blaze::DVecDVecMapExpr< VT1, VT2, OP, TF >::isAligned ( ) const
inlinenoexcept

Returns whether the operands of the expression are properly aligned in memory.

Returns
true in case the operands are aligned, false if not.

◆ leftOperand()

template<typename VT1 , typename VT2 , typename OP , bool TF>
LeftOperand blaze::DVecDVecMapExpr< VT1, VT2, OP, TF >::leftOperand ( ) const
inlinenoexcept

Returns the left-hand side dense vector operand.

Returns
The left-hand side dense vector operand.

◆ load()

template<typename VT1 , typename VT2 , typename OP , bool TF>
BLAZE_ALWAYS_INLINE auto blaze::DVecDVecMapExpr< VT1, VT2, OP, TF >::load ( size_t  index) const
inlinenoexcept

Access to the SIMD elements of the vector.

Parameters
indexAccess index. The index has to be in the range $[0..N-1]$.
Returns
Reference to the accessed values.

◆ operation()

template<typename VT1 , typename VT2 , typename OP , bool TF>
Operation blaze::DVecDVecMapExpr< VT1, VT2, OP, TF >::operation ( ) const
inline

Returns a copy of the custom operation.

Returns
A copy of the custom operation.

◆ operator[]()

template<typename VT1 , typename VT2 , typename OP , bool TF>
ReturnType blaze::DVecDVecMapExpr< VT1, VT2, OP, TF >::operator[] ( size_t  index) const
inline

Subscript operator for the direct access to the vector elements.

Parameters
indexAccess index. The index has to be in the range $[0..N-1]$.
Returns
The resulting value.

◆ operator~() [1/2]

template<typename VT, bool TF>
BLAZE_ALWAYS_INLINE VectorType& blaze::Vector< VT, TF >::operator~ ( )
inlinenoexceptinherited

Conversion operator for non-constant vectors.

Returns
Reference of the actual type of the vector.

◆ operator~() [2/2]

template<typename VT, bool TF>
BLAZE_ALWAYS_INLINE const VectorType& blaze::Vector< VT, TF >::operator~ ( ) const
inlinenoexceptinherited

Conversion operator for constant vectors.

Returns
Const reference of the actual type of the vector.

◆ rightOperand()

template<typename VT1 , typename VT2 , typename OP , bool TF>
RightOperand blaze::DVecDVecMapExpr< VT1, VT2, OP, TF >::rightOperand ( ) const
inlinenoexcept

Returns the right-hand side dense vector operand.

Returns
The right-hand side dense vector operand.

◆ size()

template<typename VT1 , typename VT2 , typename OP , bool TF>
size_t blaze::DVecDVecMapExpr< VT1, VT2, OP, TF >::size ( ) const
inlinenoexcept

Returns the current size/dimension of the vector.

Returns
The size of the vector.

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