26 template <adaptable Matrix>
34 static constexpr
size_t alignment = matrix_t::alignment;
48 template <
typename V = default_vec>
113 template <convertible_expr<value_type> E>
122 validate_assign(*
this, e);
126 if (e.alias(*
this)) {
151 template <etl_expr R>
158 validate_expression(*
this, rhs);
159 rhs.assign_add_to(*
this);
168 template <etl_expr R>
175 validate_expression(*
this, rhs);
176 rhs.assign_sub_to(*
this);
195 template <etl_expr R>
202 validate_expression(*
this, rhs);
203 rhs.assign_mul_to(*
this);
222 template <etl_expr R>
229 validate_expression(*
this, rhs);
230 rhs.assign_mul_to(*
this);
249 template <etl_expr R>
256 validate_expression(*
this, rhs);
257 rhs.assign_div_to(*
this);
276 template <etl_expr R>
283 validate_expression(*
this, rhs);
284 rhs.assign_mod_to(*
this);
297 return {
value, i, j};
300 using base_type::operator();
306 template <
typename Matrix>
static constexpr order storage_order
The storage order.
Definition: diagonal.hpp:33
CRTP class to inject iterators functions.
Definition: iterable.hpp:23
Contains diagonal matrix exception implementation.
static constexpr size_t n_dimensions
The number of dimensions.
Definition: diagonal.hpp:32
void assign_to(L &&lhs) const
Assign to the given left-hand-side expression.
Definition: adapter.hpp:279
Contains base class for adapters.
diagonal_matrix & operator/=(const R &rhs)
Modulo each element by the value of the elements in the right hand side expression.
Definition: diagonal.hpp:250
diagonal_matrix & operator>>=(const R &rhs)
Multiply each element by the value of the elements in the right hand side expression.
Definition: diagonal.hpp:223
static constexpr size_t alignment
The memory alignment.
Definition: diagonal.hpp:34
Exception that is thrown when an operation is made to a diagonal matrix that would render it non-diag...
Definition: diagonal_exception.hpp:23
diagonal_matrix & operator*=(const value_type &rhs) noexcept
Multiply each element by the right hand side scalar.
Definition: diagonal.hpp:185
typename V::template vec_type< value_type > vec_type
The vectorization type for V.
Definition: adapter.hpp:33
order
Storage order of a matrix.
Definition: order.hpp:15
void assign_mod_to(L &&lhs) const
Modulo the given left-hand-side expression.
Definition: adapter.hpp:324
void assign_div_to(L &&lhs) const
Divide the given left-hand-side expression.
Definition: adapter.hpp:315
const value_type * const_memory_type
The const memory type.
Definition: adapter.hpp:27
value_t< matrix_t > value_type
The value type.
Definition: adapter.hpp:25
Contains diagonal matrix reference proxy implementation.
diagonal_matrix & operator-=(const R &rhs)
Multiply each element by the value of the elements in the right hand side expression.
Definition: diagonal.hpp:169
Traits to get information about ETL types.
Definition: tmp.hpp:68
Root namespace for the ETL library.
Definition: adapter.hpp:15
diagonal_matrix & operator%=(const value_type &rhs) noexcept
Modulo each element by the right hand side scalar.
Definition: diagonal.hpp:266
static constexpr size_t dimensions()
Return the number of dimensions of the expression.
Definition: traits_base.hpp:31
auto dim(E &&value, size_t i) -> detail::identity_helper< E, dim_view< detail::build_identity_type< E >, D >>
Return a view representing the ith Dth dimension.
Definition: view_expression_builder.hpp:25
value_type * memory_type
The memory type.
Definition: adapter.hpp:26
adapter< Matrix > base_type
The base type.
Definition: diagonal.hpp:43
A base class for adapters.
Definition: adapter.hpp:21
bool is_diagonal(E &&expr)
Indicates if the given expression is a diagonal matrix or not.
Definition: adapters.hpp:318
matrix_t value
The adapted matrix.
Definition: adapter.hpp:36
typename matrix_t::const_iterator iterator
The type of const iterator.
Definition: diagonal.hpp:40
diagonal_matrix(size_t dim) noexcept
Construct a new diagonal matrix and fill it with zeros.
Definition: diagonal.hpp:78
typename matrix_t::const_iterator const_iterator
The type of const iterator.
Definition: diagonal.hpp:41
Represents a scalar value.
Definition: concepts_base.hpp:19
A diagonal matrix adapter.
Definition: diagonal.hpp:27
diagonal_matrix & operator*=(const R &rhs)
Multiply each element by the value of the elements in the right hand side expression.
Definition: diagonal.hpp:196
matrix_t expr_t
The wrapped expression type.
Definition: adapter.hpp:23
diagonal_matrix & operator%=(const R &rhs)
Modulo each element by the value of the elements in the right hand side expression.
Definition: diagonal.hpp:277
etl::iterator< const this_type > const_iterator
The const iterator type.
Definition: dyn_matrix_view.hpp:37
void assign_mul_to(L &&lhs) const
Multiply the given left-hand-side expression.
Definition: adapter.hpp:306
diagonal_detail::diagonal_reference< matrix_t > operator()(size_t i, size_t j) noexcept
Access the (i, j) element of the 2D matrix.
Definition: diagonal.hpp:296
diagonal_matrix(value_type value) noexcept
Construct a new diagonal matrix and fill it witht the given value.
Definition: diagonal.hpp:70
diagonal_matrix & operator+=(const R &rhs)
Multiply each element by the value of the elements in the right hand side expression.
Definition: diagonal.hpp:152
diagonal_matrix & operator=(const diagonal_matrix &rhs)=default
Assign to the matrix by copy.
diagonal_matrix() noexcept
Construct a new diagonal matrix and fill it with zeros.
Definition: diagonal.hpp:59
A proxy representing a reference to a mutable element of a diagonal matrix.
Definition: diagonal_reference.hpp:24
diagonal_matrix & operator/=(const value_type &rhs) noexcept
Divide each element by the right hand side scalar.
Definition: diagonal.hpp:239
typename decay_traits< E >::value_type value_t
Traits to extract the value type out of an ETL type.
Definition: tmp.hpp:81
diagonal_matrix & operator=(E &&e) noexcept(false)
Assign the values of the ETL expression to the diagonal matrix.
Definition: diagonal.hpp:114
Traits for wrapper expressions.
Definition: wrapper_traits.hpp:21
Matrix matrix_t
The adapted matrix type.
Definition: adapter.hpp:22
Matrix matrix_t
The adapted matrix type.
Definition: diagonal.hpp:28
diagonal_matrix & operator>>=(const value_type &rhs) noexcept
Multiply each element by the right hand side scalar.
Definition: diagonal.hpp:212