26#if ! defined (octave_MDiagArray2_h)
27#define octave_MDiagArray2_h 1
29#include "octave-config.h"
91 const T *
d = this->
data ();
95 static constexpr T zero = T ();
97 return std::count_if (
d,
d + nel,
98 [] (T elem) {
return elem != zero; });
108 OCTAVE_API bool is_multiple_of_identity (T val)
const;
130#define MDIAGARRAY2_FORWARD_DEFS(B, R, T) \
132 operator + (const R& x) \
134 return R (operator + (dynamic_cast<const B<T>&> (x))); \
137 operator - (const R& x) \
139 return R (operator - (dynamic_cast<const B<T>&> (x))); \
142 operator * (const R& x, const T& y) \
144 return R (operator * (dynamic_cast<const B<T>&> (x), (y))); \
147 operator / (const R& x, const T& y) \
149 return R (operator / (dynamic_cast<const B<T>&> (x), (y))); \
152 operator * (const T& x, const R& y) \
154 return R (operator * ( (x), dynamic_cast<const B<T>&> (y))); \
157 operator + (const R& x, const R& y) \
159 return R (operator + (dynamic_cast<const B<T>&> (x), \
160 dynamic_cast<const B<T>&> (y))); \
163 operator - (const R& x, const R& y) \
165 return R (operator - (dynamic_cast<const B<T>&> (x), \
166 dynamic_cast<const B<T>&> (y))); \
169 product (const R& x, const R& y) \
171 return R (product (dynamic_cast<const B<T>&> (x), \
172 dynamic_cast<const B<T>&> (y))); \
MDiagArray2< T > product(const MDiagArray2< T > &, const MDiagArray2< T > &)
MDiagArray2< T > operator-(const MDiagArray2< T > &)
MDiagArray2< T > operator/(const MDiagArray2< T > &, const T &)
MDiagArray2< T > operator*(const MDiagArray2< T > &, const T &)
MDiagArray2< T > operator+(const MDiagArray2< T > &)
N Dimensional Array with copy-on-write semantics.
Array< T > array_value() const
Array< T > extract_diag(octave_idx_type k=0) const
octave_idx_type length() const
DiagArray2< T > hermitian(T(*fcn)(const T &)=nullptr) const
DiagArray2< T > transpose() const
DiagArray2< T > & operator=(const DiagArray2< T > &a)
Template for N-dimensional array classes with like-type math operators.
Template for two dimensional diagonal array with math operators.
MArray< T > array_value() const
MDiagArray2(octave_idx_type r, octave_idx_type c)
MDiagArray2(const DiagArray2< U > &a)
MArray< T > diag(octave_idx_type k=0) const
octave_idx_type nnz() const
MDiagArray2(const Array< T > &a)
MDiagArray2(const DiagArray2< T > &a)
MDiagArray2(const MDiagArray2< T > &a)
MDiagArray2(const Array< T > &a, octave_idx_type r, octave_idx_type c)
MDiagArray2< T > hermitian(T(*fcn)(const T &)=nullptr) const
MDiagArray2< T > transpose() const
MDiagArray2(octave_idx_type r, octave_idx_type c, const T &val)
F77_RET_T const F77_DBLE const F77_DBLE F77_DBLE * d