Public Types | Public Member Functions | Private Types | Private Attributes | List of all members
blaze::DMatTDMatMapExpr< MT1, MT2, OP > Class Template Reference

Expression object for the dense matrix/tranpose dense matrix map() function.The DMatTDMatMapExpr class represents the compile time expression for the pairwise evaluation of a binary custom operation on the elements of a row-major dense matrix and a column-major matrix via the map() function. More...

#include <DMatTDMatMapExpr.h>

Inherits blaze::MatMatMapExpr< DenseMatrix< DMatTDMatMapExpr< MT1, MT2, OP >, false > >, and blaze::Computation.

Public Types

enum  : bool { simdEnabled = false }
 Compilation switch for the expression template evaluation strategy.
 
enum  : bool { smpAssignable = MT1::smpAssignable && MT2::smpAssignable }
 Compilation switch for the expression template assignment strategy.
 
using This = DMatTDMatMapExpr< MT1, MT2, OP >
 Type of this DMatTDMatMapExpr instance.
 
using ResultType = BinaryMapTrait_< RT1, RT2, OP >
 Result type for expression template evaluations.
 
using OppositeType = OppositeType_< ResultType >
 Result type with opposite storage order 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 DMatTDMatMapExpr &>
 Data type for composite expression templates.
 
using LeftOperand = If_< IsExpression< MT1 >, const MT1, const MT1 &>
 Composite type of the left-hand side dense matrix expression.
 
using RightOperand = If_< IsExpression< MT2 >, const MT2, const MT2 &>
 Composite type of the right-hand side dense matrix expression.
 
using Operation = OP
 Data type of the custom unary operation.
 
using LT = If_< RequiresEvaluation< MT1 >, const RT1, CT1 >
 Type for the assignment of the left-hand side dense matrix operand.
 
using RT = If_< RequiresEvaluation< MT2 >, const RT2, CT2 >
 Type for the assignment of the right-hand side dense matrix operand.
 
using MatrixType = MT
 Type of the matrix.
 

Public Member Functions

 DMatTDMatMapExpr (const MT1 &lhs, const MT2 &rhs, OP op) noexcept
 Constructor for the DMatTDMatMapExpr class. More...
 
ReturnType operator() (size_t i, size_t j) const
 2D-access to the matrix elements. More...
 
ReturnType at (size_t i, size_t j) const
 Checked access to the matrix elements. More...
 
size_t rows () const noexcept
 Returns the current number of rows of the matrix. More...
 
size_t columns () const noexcept
 Returns the current number of columns of the matrix. More...
 
LeftOperand leftOperand () const noexcept
 Returns the left-hand side dense matrix operand. More...
 
RightOperand rightOperand () const noexcept
 Returns the right-hand side dense matrix 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 MatrixTypeoperator~ () noexcept
 Conversion operator for non-constant matrices. More...
 
BLAZE_ALWAYS_INLINE const MatrixTypeoperator~ () const noexcept
 Conversion operator for constant matrices. More...
 

Private Types

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

Private Attributes

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

Detailed Description

template<typename MT1, typename MT2, typename OP>
class blaze::DMatTDMatMapExpr< MT1, MT2, OP >

Expression object for the dense matrix/tranpose dense matrix map() function.

The DMatTDMatMapExpr class represents the compile time expression for the pairwise evaluation of a binary custom operation on the elements of a row-major dense matrix and a column-major matrix via the map() function.

Member Enumeration Documentation

◆ anonymous enum

template<typename MT1, typename MT2, typename OP>
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 matrix 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

◆ DMatTDMatMapExpr()

template<typename MT1, typename MT2, typename OP>
blaze::DMatTDMatMapExpr< MT1, MT2, OP >::DMatTDMatMapExpr ( const MT1 &  lhs,
const MT2 &  rhs,
OP  op 
)
inlineexplicitnoexcept

Constructor for the DMatTDMatMapExpr class.

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

Member Function Documentation

◆ at()

template<typename MT1, typename MT2, typename OP>
ReturnType blaze::DMatTDMatMapExpr< MT1, MT2, OP >::at ( size_t  i,
size_t  j 
) const
inline

Checked access to the matrix elements.

Parameters
iAccess index for the row. The index has to be in the range $[0..M-1]$.
jAccess index for the column. The index has to be in the range $[0..N-1]$.
Returns
The resulting value.
Exceptions
std::out_of_rangeInvalid matrix access index.

◆ canAlias()

template<typename MT1, typename MT2, typename OP>
template<typename T >
bool blaze::DMatTDMatMapExpr< MT1, MT2, OP >::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 MT1, typename MT2, typename OP>
bool blaze::DMatTDMatMapExpr< MT1, MT2, OP >::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.

◆ columns()

template<typename MT1, typename MT2, typename OP>
size_t blaze::DMatTDMatMapExpr< MT1, MT2, OP >::columns ( ) const
inlinenoexcept

Returns the current number of columns of the matrix.

Returns
The number of columns of the matrix.

◆ isAliased()

template<typename MT1, typename MT2, typename OP>
template<typename T >
bool blaze::DMatTDMatMapExpr< MT1, MT2, OP >::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 MT1, typename MT2, typename OP>
bool blaze::DMatTDMatMapExpr< MT1, MT2, OP >::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 MT1, typename MT2, typename OP>
LeftOperand blaze::DMatTDMatMapExpr< MT1, MT2, OP >::leftOperand ( ) const
inlinenoexcept

Returns the left-hand side dense matrix operand.

Returns
The left-hand side dense matrix operand.

◆ operation()

template<typename MT1, typename MT2, typename OP>
Operation blaze::DMatTDMatMapExpr< MT1, MT2, OP >::operation ( ) const
inline

Returns a copy of the custom operation.

Returns
A copy of the custom operation.

◆ operator()()

template<typename MT1, typename MT2, typename OP>
ReturnType blaze::DMatTDMatMapExpr< MT1, MT2, OP >::operator() ( size_t  i,
size_t  j 
) const
inline

2D-access to the matrix elements.

Parameters
iAccess index for the row. The index has to be in the range $[0..M-1]$.
jAccess index for the column. The index has to be in the range $[0..N-1]$.
Returns
The resulting value.

◆ operator~() [1/2]

template<typename MT, bool SO>
BLAZE_ALWAYS_INLINE MatrixType& blaze::Matrix< MT, SO >::operator~ ( )
inlinenoexceptinherited

Conversion operator for non-constant matrices.

Returns
Reference of the actual type of the matrix.

◆ operator~() [2/2]

template<typename MT, bool SO>
BLAZE_ALWAYS_INLINE const MatrixType& blaze::Matrix< MT, SO >::operator~ ( ) const
inlinenoexceptinherited

Conversion operator for constant matrices.

Returns
Constant reference of the actual type of the matrix.

◆ rightOperand()

template<typename MT1, typename MT2, typename OP>
RightOperand blaze::DMatTDMatMapExpr< MT1, MT2, OP >::rightOperand ( ) const
inlinenoexcept

Returns the right-hand side dense matrix operand.

Returns
The right-hand side dense matrix operand.

◆ rows()

template<typename MT1, typename MT2, typename OP>
size_t blaze::DMatTDMatMapExpr< MT1, MT2, OP >::rows ( ) const
inlinenoexcept

Returns the current number of rows of the matrix.

Returns
The number of rows of the matrix.

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