Expression object for dense matrix-transpose sparse matrix Schur product.The DMatTSMatSchurExpr class represents the compile time expression for Schur products between a dense matrix and a column-major sparse matrix.
More...
#include <DMatTSMatSchurExpr.h>
Inherits blaze::SchurExpr< SparseMatrix< DMatTSMatSchurExpr< MT1, MT2 >, true > >, and blaze::Computation.
|
class | ConstIterator |
| Iterator over the elements of the dense matrix/sparse matrix Schur product expression. More...
|
|
|
enum | : bool { smpAssignable = false
} |
| Compilation switch for the expression template assignment strategy.
|
|
using | This = DMatTSMatSchurExpr< MT1, MT2 > |
| Type of this DMatTSMatSchurExpr instance.
|
|
using | ResultType = SchurTrait_< RT1, RT2 > |
| 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 = const IfTrue_< returnExpr, ExprReturnType, ElementType > |
| Return type for expression template evaluations.
|
|
using | CompositeType = IfTrue_< useAssign, const ResultType, const DMatTSMatSchurExpr &> |
| 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 sparse matrix expression.
|
|
using | MatrixType = DMatTSMatSchurExpr< MT1, MT2 > |
| Type of the matrix.
|
|
|
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<MT1>::value || RequiresEvaluation<MT2>::value )
} |
| Compilation switch for the evaluation strategy of the Schur product 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 sparse 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 sparse 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 sparse matrix expression.
|
|
using | ExprReturnType = MultExprTrait_< RN1, RN2 > |
| Expression return type for the subscript operator.
|
|
|
LeftOperand | lhs_ |
| Left-hand side dense matrix of the Schur product expression.
|
|
RightOperand | rhs_ |
| Right-hand side sparse matrix of the Schur product expression.
|
|
template<typename MT1, typename MT2>
class blaze::DMatTSMatSchurExpr< MT1, MT2 >
Expression object for dense matrix-transpose sparse matrix Schur product.
The DMatTSMatSchurExpr class represents the compile time expression for Schur products between a dense matrix and a column-major sparse matrix.
◆ anonymous enum
template<typename MT1, typename MT2>
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 matrix operand returns a temporary vector or matrix, returnExpr will be set to false and the subscript operator will return it's result by value. Otherwise returnExpr will be set to true and the subscript operator may return it's result as an expression.
◆ anonymous enum
template<typename MT1, typename MT2>
Compilation switch for the evaluation strategy of the Schur product expression.
The useAssign compile time constant expression represents a compilation switch for the evaluation strategy of the Schur product expression. In case either the dense or the sparse matrix operand requires an intermediate evaluation, useAssign will be set to true and the Schur product expression will be evaluated via the assign function family. Otherwise useAssign will be set to false and the expression will be evaluated via the function call operator.
◆ DMatTSMatSchurExpr()
template<typename MT1, typename MT2>
Constructor for the DMatTSMatSchurExpr class.
- Parameters
-
lhs | The left-hand side dense matrix operand of the Schur product expression. |
rhs | The right-hand side sparse matrix operand of the Schur product expression. |
◆ at()
template<typename MT1, typename MT2>
Checked access to the matrix elements.
- Parameters
-
i | Access index for the row. The index has to be in the range . |
j | Access index for the column. The index has to be in the range . |
- Returns
- The resulting value.
- Exceptions
-
std::out_of_range | Invalid matrix access index. |
◆ begin()
template<typename MT1, typename MT2>
Returns an iterator to the first non-zero element of column j.
- Parameters
-
- Returns
- Iterator to the first non-zero element of column j.
◆ canAlias()
template<typename MT1, typename MT2>
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 effect is detected, false otherwise.
◆ columns()
template<typename MT1, typename MT2>
Returns the current number of columns of the matrix.
- Returns
- The number of columns of the matrix.
◆ end()
template<typename MT1, typename MT2>
Returns an iterator just past the last non-zero element of column j.
- Parameters
-
- Returns
- Iterator just past the last non-zero element of column j.
◆ find()
template<typename MT1, typename MT2>
Searches for a specific matrix element.
- Parameters
-
i | The row index of the search element. |
j | The column index of the search element. |
- Returns
- Iterator to the element in case the index is found, end() iterator otherwise.
◆ isAliased()
template<typename MT1, typename MT2>
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.
◆ leftOperand()
template<typename MT1, typename MT2>
Returns the left-hand side dense matrix operand.
- Returns
- The left-hand side dense matrix operand.
◆ lowerBound()
template<typename MT1, typename MT2>
Returns an iterator to the first index not less then the given index.
- Parameters
-
i | The row index of the search element. |
j | The column index of the search element. |
- Returns
- Iterator to the first index not less then the given index, end() iterator otherwise.
◆ nonZeros() [1/2]
template<typename MT1, typename MT2>
Returns the number of non-zero elements in the sparse matrix.
- Returns
- The number of non-zero elements in the sparse matrix.
◆ nonZeros() [2/2]
template<typename MT1, typename MT2>
Returns the number of non-zero elements in the specified column.
- Parameters
-
j | The index of the column. |
- Returns
- The number of non-zero elements of column j.
◆ operator()()
template<typename MT1, typename MT2>
2D-access to the matrix elements.
- Parameters
-
i | Access index for the row. The index has to be in the range . |
j | Access index for the column. The index has to be in the range . |
- Returns
- The resulting value.
◆ operator~() [1/2]
Conversion operator for non-constant matrices.
- Returns
- Reference of the actual type of the matrix.
◆ operator~() [2/2]
Conversion operator for constant matrices.
- Returns
- Constant reference of the actual type of the matrix.
◆ rightOperand()
template<typename MT1, typename MT2>
Returns the right-hand side transpose sparse matrix operand.
- Returns
- The right-hand side transpose sparse matrix operand.
◆ rows()
template<typename MT1, typename MT2>
Returns the current number of rows of the matrix.
- Returns
- The number of rows of the matrix.
◆ upperBound()
template<typename MT1, typename MT2>
Returns an iterator to the first index greater then the given index.
- Parameters
-
i | The row index of the search element. |
j | The column index of the search element. |
- Returns
- Iterator to the first index greater then the given index, end() iterator otherwise.
The documentation for this class was generated from the following file: