Public Types | Public Member Functions | Private Types | Private Attributes | List of all members
blaze::DMatDeclSymExpr< MT, SO > Class Template Reference

Expression object for the explicit symmetry declaration of dense matrices.The DMatDeclSymExpr class represents the compile time expression for the explicit symmetry declaration of a dense matrix. More...

#include <DMatDeclSymExpr.h>

Inherits blaze::DeclSymExpr< DenseMatrix< DMatDeclSymExpr< MT, SO >, SO > >, and blaze::Declaration< MT >.

Public Types

enum  : bool { simdEnabled = MT::simdEnabled }
 Compilation switch for the expression template evaluation strategy.
 
enum  : bool { smpAssignable = MT::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 = DMatDeclSymExpr< MT, SO >
 Type of this DMatDeclSymExpr instance.
 
using ResultType = DeclSymTrait_< RT >
 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_< MT >
 Resulting element type.
 
using ReturnType = ReturnType_< MT >
 Return type for expression template evaluations.
 
using CompositeType = If_< RequiresEvaluation< MT >, const ResultType, const DMatDeclSymExpr &>
 Data type for composite expression templates.
 
using ConstIterator = typename GetConstIterator< MT >::Type
 Iterator over the elements of the dense matrix.
 
using Operand = If_< IsExpression< MT >, const MT, const MT &>
 Composite data type of the dense matrix expression.
 
using MatrixType = MT
 Type of the matrix.
 

Public Member Functions

 DMatDeclSymExpr (const MT &dm) noexcept
 Constructor for the DMatDeclSymExpr 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...
 
BLAZE_ALWAYS_INLINE auto load (size_t i, size_t j) const noexcept
 Access to the SIMD elements of the matrix. More...
 
const ElementTypedata () const noexcept
 Low-level data access to the matrix elements. More...
 
ConstIterator begin (size_t i) const
 Returns an iterator to the first non-zero element of row/column i. More...
 
ConstIterator end (size_t i) const
 Returns an iterator just past the last non-zero element of row/column i. 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...
 
Operand operand () const noexcept
 Returns the dense matrix operand. 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<MT>::value }
 Compilation switch for the serial evaluation strategy of the symmetry declaration expression. More...
 
using RT = ResultType_< MT >
 Result type of the dense matrix expression.
 

Private Attributes

Operand dm_
 Dense matrix of the declsym expression.
 

Detailed Description

template<typename MT, bool SO>
class blaze::DMatDeclSymExpr< MT, SO >

Expression object for the explicit symmetry declaration of dense matrices.

The DMatDeclSymExpr class represents the compile time expression for the explicit symmetry declaration of a dense matrix.

Member Enumeration Documentation

◆ anonymous enum

template<typename MT, bool SO>
anonymous enum : bool
private

Compilation switch for the serial evaluation strategy of the symmetry declaration expression.

The useAssign compile time constant expression represents a compilation switch for the serial evaluation strategy of the symmetry declaration expression. In case the given dense matrix expression of type MT requires an intermediate evaluation, useAssign will be set to 1 and the symmetry declaration 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

◆ DMatDeclSymExpr()

template<typename MT, bool SO>
blaze::DMatDeclSymExpr< MT, SO >::DMatDeclSymExpr ( const MT &  dm)
inlineexplicitnoexcept

Constructor for the DMatDeclSymExpr class.

Parameters
dmThe dense matrix operand of the declsym expression.

Member Function Documentation

◆ at()

template<typename MT, bool SO>
ReturnType blaze::DMatDeclSymExpr< MT, SO >::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.

◆ begin()

template<typename MT, bool SO>
ConstIterator blaze::DMatDeclSymExpr< MT, SO >::begin ( size_t  i) const
inline

Returns an iterator to the first non-zero element of row/column i.

Parameters
iThe row/column index.
Returns
Iterator to the first non-zero element of row/column i.

◆ canAlias()

template<typename MT, bool SO>
template<typename T >
bool blaze::DMatDeclSymExpr< MT, SO >::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 MT, bool SO>
bool blaze::DMatDeclSymExpr< MT, SO >::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 MT, bool SO>
size_t blaze::DMatDeclSymExpr< MT, SO >::columns ( ) const
inlinenoexcept

Returns the current number of columns of the matrix.

Returns
The number of columns of the matrix.

◆ data()

template<typename MT, bool SO>
const ElementType* blaze::DMatDeclSymExpr< MT, SO >::data ( ) const
inlinenoexcept

Low-level data access to the matrix elements.

Returns
Pointer to the internal element storage.

◆ end()

template<typename MT, bool SO>
ConstIterator blaze::DMatDeclSymExpr< MT, SO >::end ( size_t  i) const
inline

Returns an iterator just past the last non-zero element of row/column i.

Parameters
iThe row/column index.
Returns
Iterator just past the last non-zero element of row/column i.

◆ isAliased()

template<typename MT, bool SO>
template<typename T >
bool blaze::DMatDeclSymExpr< MT, SO >::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 MT, bool SO>
bool blaze::DMatDeclSymExpr< MT, SO >::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.

◆ load()

template<typename MT, bool SO>
BLAZE_ALWAYS_INLINE auto blaze::DMatDeclSymExpr< MT, SO >::load ( size_t  i,
size_t  j 
) const
inlinenoexcept

Access to the SIMD elements of the matrix.

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
Reference to the accessed values.

◆ operand()

template<typename MT, bool SO>
Operand blaze::DMatDeclSymExpr< MT, SO >::operand ( ) const
inlinenoexcept

Returns the dense matrix operand.

Returns
The dense matrix operand.

◆ operator()()

template<typename MT, bool SO>
ReturnType blaze::DMatDeclSymExpr< MT, SO >::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.

◆ rows()

template<typename MT, bool SO>
size_t blaze::DMatDeclSymExpr< MT, SO >::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: