Expression object for the non-aliased evaluation of sparse vectors.
More...
#include <SVecNoAliasExpr.h>
Inherits blaze::VecNoAliasExpr< SparseVector< SVecNoAliasExpr< VT, TF >, TF > >, and blaze::Modification< VT >.
|
using | This = SVecNoAliasExpr< VT, TF > |
| Type of this SVecNoAliasExpr instance.
|
|
using | BaseType = VecNoAliasExpr< SparseVector< This, TF > > |
| Base type of this SVecNoAliasExpr instance.
|
|
using | ResultType = ResultType_t< VT > |
| Result type for expression template evaluations.
|
|
using | TransposeType = TransposeType_t< VT > |
| Transpose type for expression template evaluations.
|
|
using | ElementType = ElementType_t< VT > |
| Resulting element type.
|
|
using | ReturnType = ReturnType_t< VT > |
| Return type for expression template evaluations.
|
|
using | CompositeType = If_t< RequiresEvaluation_v< VT >, const ResultType, const SVecNoAliasExpr & > |
| Data type for composite expression templates.
|
|
using | ConstIterator = GetConstIterator_t< VT > |
| Iterator over the elements of the dense vector.
|
|
using | Operand = If_t< IsExpression_v< VT >, const VT, const VT & > |
| Composite data type of the sparse vector expression.
|
|
using | VectorType = SVecNoAliasExpr< VT, TF > |
| Type of the vector.
|
|
|
static constexpr bool | smpAssignable = VT::smpAssignable |
| Compilation switch for the expression template assignment strategy.
|
|
static constexpr bool | transposeFlag |
| Transpose flag of the vector.
|
|
|
| BLAZE_CREATE_GET_TYPE_MEMBER_TYPE_TRAIT (GetConstIterator, ConstIterator, INVALID_TYPE) |
| Definition of the GetConstIterator type trait.
|
|
|
Operand | sv_ |
| Sparse vector of the no-alias expression.
|
|
template<typename VT, bool TF>
class blaze::SVecNoAliasExpr< VT, TF >
Expression object for the non-aliased evaluation of sparse vectors.
The SVecNoAliasExpr class represents the compile time expression for the non-aliased evaluation of a sparse vector.
◆ SVecNoAliasExpr()
template<typename VT , bool TF>
Constructor for the SVecNoAliasExpr class.
- Parameters
-
sv | The sparse vector operand of the no-alias expression. |
◆ at()
template<typename VT , 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 VT , bool TF>
Returns an iterator to the first non-zero element of the sparse vector.
- Returns
- Iterator to the first non-zero element of the sparse vector.
◆ canAlias()
template<typename VT , 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 VT , 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 VT , bool TF>
Returns an iterator just past the last non-zero element of the sparse vector.
- Returns
- Iterator just past the last non-zero element of the sparse vector.
◆ find()
template<typename VT , bool TF>
Searches for a specific vector element.
- Parameters
-
index | The index of the search element. |
- Returns
- Iterator to the element in case the index is found, end() iterator otherwise.
◆ isAliased()
template<typename VT , 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.
◆ lowerBound()
template<typename VT , bool TF>
Returns an iterator to the first index not less then the given index.
- Parameters
-
index | The index of the search element. |
- Returns
- Iterator to the first index not less then the given index, end() iterator otherwise.
◆ nonZeros()
template<typename VT , bool TF>
Returns the number of non-zero elements in the sparse vector.
- Returns
- The number of non-zero elements in the sparse vector.
◆ operand()
template<typename VT , bool TF>
Returns the sparse vector operand.
- Returns
- The sparse vector operand.
◆ operator*() [1/2]
|
constexprnoexceptinherited |
CRTP-based conversion operation for constant vectors.
- Returns
- Const reference of the actual type of the vector.
This operator performs the CRTP-based type-safe downcast to the actual type VT of the vector. It will return a constant reference to the actual type VT.
◆ operator*() [2/2]
|
constexprnoexceptinherited |
CRTP-based conversion operation for non-constant vectors.
- Returns
- Mutable reference of the actual type of the vector.
This operator performs the CRTP-based type-safe downcast to the actual type VT of the vector. It will return a mutable reference to the actual type VT.
◆ operator[]()
template<typename VT , 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]
|
constexprnoexceptinherited |
CRTP-based conversion operation for constant vectors.
- Returns
- Constant reference of the actual type of the vector.
This operator performs the CRTP-based type-safe downcast to the actual type VT of the vector. It will return a constant reference to the actual type VT.
◆ operator~() [2/2]
|
constexprnoexceptinherited |
CRTP-based conversion operation for non-constant vectors.
- Returns
- Mutable reference of the actual type of the vector.
This operator performs the CRTP-based type-safe downcast to the actual type VT of the vector. It will return a mutable reference to the actual type VT.
◆ size()
template<typename VT , bool TF>
Returns the current size/dimension of the vector.
- Returns
- The size of the vector.
◆ upperBound()
template<typename VT , bool TF>
Returns an iterator to the first index greater then the given index.
- Parameters
-
index | The 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 files: