Expression object for dense vector-dense vector additions.The DVecDVecAddExpr class represents the compile time expression for additions between dense vectors.
More...
#include <DVecDVecAddExpr.h>
Inherits blaze::VecVecAddExpr< DenseVector< DVecDVecAddExpr< VT1, VT2, TF >, TF > >, and blaze::Computation.
|
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 = DVecDVecAddExpr< VT1, VT2, TF > |
| Type of this DVecDVecAddExpr instance.
|
|
using | ResultType = AddTrait_< RE1, RE2 > |
| 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 = const IfTrue_< returnExpr, ExprReturnType, ElementType > |
| Return type for expression template evaluations.
|
|
using | CompositeType = IfTrue_< useAssign, const ResultType, const DVecDVecAddExpr &> |
| 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 | VectorType = VT |
| Type of the vector.
|
|
|
enum | : bool { returnExpr = !IsTemporary<RN1>::value && !IsTemporary<RN2>::value
} |
| Compilation switch for the selection of the subscript operator return type. More...
|
|
enum | : bool { useAssign = ( RequiresEvaluation<VT1>::value || RequiresEvaluation<VT2>::value || !returnExpr )
} |
| Compilation switch for the serial evaluation strategy of the addition expression. More...
|
|
using | RE1 = ResultType_< VT1 > |
| Result type of the left-hand side dense vector expression.
|
|
using | RE2 = ResultType_< VT2 > |
| Result 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.
|
|
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 | ExprReturnType = AddExprTrait_< RN1, RN2 > |
| Expression return type for the subscript operator.
|
|
template<typename VT1, typename VT2, bool TF>
class blaze::DVecDVecAddExpr< VT1, VT2, TF >
Expression object for dense vector-dense vector additions.
The DVecDVecAddExpr class represents the compile time expression for additions between dense vectors.
◆ anonymous enum
template<typename VT1 , typename VT2 , bool TF>
Compilation switch for the selection of the subscript operator return type.
The returnExpr compile time constant expression is a compilation switch for the selection of the ReturnType. If either vector operand returns a temporary vector or matrix, returnExpr will be set to 0 and the subscript operator will return it's result by value. Otherwise returnExpr will be set to 1 and the subscript operator may return it's result as an expression.
◆ anonymous enum
template<typename VT1 , typename VT2 , bool TF>
Compilation switch for the serial evaluation strategy of the addition expression.
The useAssign compile time constant expression represents a compilation switch for the serial evaluation strategy of the addition expression. In case either of the two dense vector operands requires an intermediate evaluation or the subscript operator can only return by value, 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.
◆ DVecDVecAddExpr()
template<typename VT1 , typename VT2 , bool TF>
Constructor for the DVecDVecAddExpr class.
- Parameters
-
lhs | The left-hand side operand of the addition expression. |
rhs | The right-hand side operand of the addition expression. |
◆ at()
template<typename VT1 , typename VT2 , bool TF>
Checked access to the vector elements.
- Parameters
-
index | Access index. The index has to be in the range . |
- Returns
- The resulting value.
- Exceptions
-
std::out_of_range | Invalid vector access index. |
◆ begin()
template<typename VT1 , typename VT2 , bool TF>
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 , bool TF>
template<typename T >
Returns whether the expression can alias with the given address alias.
- Parameters
-
alias | The alias to be checked. |
- Returns
- true in case the expression can alias, false otherwise.
◆ canSMPAssign()
template<typename VT1 , typename VT2 , bool TF>
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 , bool TF>
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 , bool TF>
template<typename T >
Returns whether the expression is aliased with the given address alias.
- Parameters
-
alias | The alias to be checked. |
- Returns
- true in case an alias effect is detected, false otherwise.
◆ isAligned()
template<typename VT1 , typename VT2 , bool TF>
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 , bool TF>
Returns the left-hand side dense vector operand.
- Returns
- The left-hand side dense vector operand.
◆ load()
template<typename VT1 , typename VT2 , bool TF>
Access to the SIMD elements of the vector.
- Parameters
-
index | Access index. The index has to be in the range . |
- Returns
- Reference to the accessed values.
◆ operator[]()
template<typename VT1 , typename VT2 , bool TF>
Subscript operator for the direct access to the vector elements.
- Parameters
-
index | Access index. The index has to be in the range . |
- Returns
- The resulting value.
◆ operator~() [1/2]
template<typename VT, bool TF>
Conversion operator for non-constant vectors.
- Returns
- Reference of the actual type of the vector.
◆ operator~() [2/2]
template<typename VT, bool TF>
Conversion operator for constant vectors.
- Returns
- Const reference of the actual type of the vector.
◆ rightOperand()
template<typename VT1 , typename VT2 , bool TF>
Returns the right-hand side dense vector operand.
- Returns
- The right-hand side dense vector operand.
◆ size()
template<typename VT1 , typename VT2 , bool TF>
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: