#include "fDiagMatrix.h"
Public Types | |
| typedef FloatMatrix | full_matrix_type |
Friends | |
| FloatDiagMatrix | imag (const FloatComplexDiagMatrix &a) |
| std::ostream & | operator<< (std::ostream &os, const FloatDiagMatrix &a) |
| FloatDiagMatrix | real (const FloatComplexDiagMatrix &a) |
Additional Inherited Members | |
Protected Types inherited from Array< T > | |
| typedef bool(* | compare_fcn_type) (typename ref_param< T >::type, typename ref_param< T >::type) |
| typedef ref_param< T >::type | crefT |
| typedef T | element_type |
| typedef octave_idx_type | size_type |
| Used for operator(), and returned by numel() and size() (beware: signed integer) | |
| typedef T | value_type |
Protected Member Functions inherited from Array< T > | |
| Array (const Array< T, Alloc > &a, const dim_vector &dv, octave_idx_type l, octave_idx_type u) | |
| slice constructor | |
| Array () | |
| Empty ctor (0 by 0). | |
| Array (Array< T, Alloc > &&a) | |
| Array (const Array< T, Alloc > &a) | |
| No type conversion case. | |
| Array (const Array< T, Alloc > &a, const dim_vector &dv) | |
| Reshape constructor. | |
| Array (const Array< U, A > &a) | |
| Type conversion case. | |
| Array (const Container< T > &a, const dim_vector &dv) | |
| Constructor from standard library sequence containers. | |
| Array (const dim_vector &dv) | |
| nD uninitialized ctor. | |
| Array (const dim_vector &dv, const T &val) | |
| nD initialized ctor. | |
| Array (T *ptr, const dim_vector &dv, const Alloc &xallocator=Alloc()) | |
| virtual | ~Array () |
| Array< T, Alloc > | as_column () const |
| Return the array as a column vector. | |
| Array< T, Alloc > | as_matrix () const |
| Return the array as a matrix. | |
| Array< T, Alloc > | as_row () const |
| Return the array as a row vector. | |
| void | clear () |
| void | clear (const dim_vector &dv) |
| void | clear (octave_idx_type r, octave_idx_type c) |
| void | fill (const T &val) |
| Array< octave_idx_type > | find (octave_idx_type, bool) const |
| Array< octave_idx_type > | find (octave_idx_type, bool) const |
| sortmode | is_sorted_rows (sortmode) const |
| sortmode | is_sorted_rows (sortmode) const |
| sortmode | issorted (sortmode) const |
| sortmode | issorted (sortmode) const |
| Array< octave_idx_type > | lookup (const Array< octave::cdef_object > &, sortmode) const |
| Array< octave_idx_type > | lookup (const Array< octave::idx_vector > &, sortmode) const |
| octave_idx_type | lookup (octave::cdef_object const &, sortmode) const |
| octave_idx_type | lookup (octave::idx_vector const &, sortmode) const |
| void | make_unique () |
| octave_idx_type | nnz () const |
| octave_idx_type | nnz () const |
| Array< octave::cdef_object > | nth_element (const octave::idx_vector &, int) const |
| Array< octave::idx_vector > | nth_element (const octave::idx_vector &, int) const |
| octave_idx_type | numel () const |
| Number of elements in the array. | |
| Array< T, Alloc > & | operator= (Array< T, Alloc > &&a) |
| Array< T, Alloc > & | operator= (const Array< T, Alloc > &a) |
| Array< octave::cdef_object > | sort (Array< octave_idx_type > &sidx, int, sortmode) const |
| Array< octave::idx_vector > | sort (Array< octave_idx_type > &sidx, int, sortmode) const |
| Array< octave::cdef_object > | sort (int, sortmode) const |
| Array< octave::idx_vector > | sort (int, sortmode) const |
| Array< octave_idx_type > | sort_rows_idx (sortmode) const |
| Array< octave_idx_type > | sort_rows_idx (sortmode) const |
| octave_idx_type | dim1 () const |
| octave_idx_type | rows () const |
| octave_idx_type | dim2 () const |
| octave_idx_type | cols () const |
| octave_idx_type | columns () const |
| octave_idx_type | dim3 () const |
| Size of the specified dimension. | |
| octave_idx_type | pages () const |
| Size of the specified dimension. | |
| size_type | size (const size_type d) const |
| Size of the specified dimension. | |
| std::size_t | byte_size () const |
| Size of the specified dimension. | |
| const dim_vector & | dims () const |
| Return a const-reference so that dims ()(i) works efficiently. | |
| Array< T, Alloc > | squeeze () const |
| Chop off leading singleton dimensions. | |
| octave_idx_type | compute_index (octave_idx_type i, octave_idx_type j) const |
| Size of the specified dimension. | |
| octave_idx_type | compute_index (octave_idx_type i, octave_idx_type j, octave_idx_type k) const |
| Size of the specified dimension. | |
| octave_idx_type | compute_index (const Array< octave_idx_type > &ra_idx) const |
| Size of the specified dimension. | |
| octave_idx_type | compute_index_unchecked (const Array< octave_idx_type > &ra_idx) const |
| Size of the specified dimension. | |
| T & | xelem (octave_idx_type n) |
| Size of the specified dimension. | |
| crefT | xelem (octave_idx_type n) const |
| Size of the specified dimension. | |
| T & | xelem (octave_idx_type i, octave_idx_type j) |
| Size of the specified dimension. | |
| crefT | xelem (octave_idx_type i, octave_idx_type j) const |
| Size of the specified dimension. | |
| T & | xelem (octave_idx_type i, octave_idx_type j, octave_idx_type k) |
| Size of the specified dimension. | |
| crefT | xelem (octave_idx_type i, octave_idx_type j, octave_idx_type k) const |
| Size of the specified dimension. | |
| T & | xelem (const Array< octave_idx_type > &ra_idx) |
| Size of the specified dimension. | |
| crefT | xelem (const Array< octave_idx_type > &ra_idx) const |
| Size of the specified dimension. | |
| T & | checkelem (octave_idx_type n) |
| Size of the specified dimension. | |
| T & | checkelem (octave_idx_type i, octave_idx_type j) |
| Size of the specified dimension. | |
| T & | checkelem (octave_idx_type i, octave_idx_type j, octave_idx_type k) |
| Size of the specified dimension. | |
| T & | checkelem (const Array< octave_idx_type > &ra_idx) |
| Size of the specified dimension. | |
| crefT | checkelem (octave_idx_type n) const |
| Size of the specified dimension. | |
| crefT | checkelem (octave_idx_type i, octave_idx_type j) const |
| Size of the specified dimension. | |
| crefT | checkelem (octave_idx_type i, octave_idx_type j, octave_idx_type k) const |
| Size of the specified dimension. | |
| crefT | checkelem (const Array< octave_idx_type > &ra_idx) const |
| Size of the specified dimension. | |
| T & | elem (octave_idx_type n) |
| Size of the specified dimension. | |
| T & | elem (octave_idx_type i, octave_idx_type j) |
| Size of the specified dimension. | |
| T & | elem (octave_idx_type i, octave_idx_type j, octave_idx_type k) |
| Size of the specified dimension. | |
| T & | elem (const Array< octave_idx_type > &ra_idx) |
| Size of the specified dimension. | |
| crefT | elem (octave_idx_type n) const |
| Size of the specified dimension. | |
| crefT | elem (octave_idx_type i, octave_idx_type j) const |
| Size of the specified dimension. | |
| crefT | elem (octave_idx_type i, octave_idx_type j, octave_idx_type k) const |
| Size of the specified dimension. | |
| crefT | elem (const Array< octave_idx_type > &ra_idx) const |
| Size of the specified dimension. | |
| T & | operator() (octave_idx_type n) |
| Size of the specified dimension. | |
| T & | operator() (octave_idx_type i, octave_idx_type j) |
| Size of the specified dimension. | |
| T & | operator() (octave_idx_type i, octave_idx_type j, octave_idx_type k) |
| Size of the specified dimension. | |
| T & | operator() (const Array< octave_idx_type > &ra_idx) |
| Size of the specified dimension. | |
| crefT | operator() (octave_idx_type n) const |
| Size of the specified dimension. | |
| crefT | operator() (octave_idx_type i, octave_idx_type j) const |
| Size of the specified dimension. | |
| crefT | operator() (octave_idx_type i, octave_idx_type j, octave_idx_type k) const |
| Size of the specified dimension. | |
| crefT | operator() (const Array< octave_idx_type > &ra_idx) const |
| Size of the specified dimension. | |
| Array< T, Alloc > | column (octave_idx_type k) const |
| Extract column: A(:,k+1). | |
| Array< T, Alloc > | page (octave_idx_type k) const |
| Extract page: A(:,:,k+1). | |
| Array< T, Alloc > | linear_slice (octave_idx_type lo, octave_idx_type up) const |
| Extract a slice from this array as a column vector: A(:)(lo+1:up). | |
| Array< T, Alloc > | reshape (octave_idx_type nr, octave_idx_type nc) const |
| Size of the specified dimension. | |
| Array< T, Alloc > | reshape (const dim_vector &new_dims) const |
| Size of the specified dimension. | |
| Array< T, Alloc > | permute (const Array< octave_idx_type > &vec, bool inv=false) const |
| Size of the specified dimension. | |
| Array< T, Alloc > | ipermute (const Array< octave_idx_type > &vec) const |
| Size of the specified dimension. | |
| bool | issquare () const |
| Size of the specified dimension. | |
| bool | isempty () const |
| Size of the specified dimension. | |
| bool | isvector () const |
| Size of the specified dimension. | |
| bool | is_nd_vector () const |
| Size of the specified dimension. | |
| Array< T, Alloc > | transpose () const |
| Size of the specified dimension. | |
| Array< T, Alloc > | hermitian (T(*fcn)(const T &)=nullptr) const |
| Size of the specified dimension. | |
| const T * | data () const |
| Size of the specified dimension. | |
| T * | rwdata () |
| Size of the specified dimension. | |
| T * | fortran_vec () |
| Size of the specified dimension. | |
| bool | is_shared () const |
| Size of the specified dimension. | |
| int | ndims () const |
| Size of the specified dimension. | |
| Array< T, Alloc > | index (const octave::idx_vector &i) const |
| Indexing without resizing. | |
| Array< T, Alloc > | index (const octave::idx_vector &i, const octave::idx_vector &j) const |
| Size of the specified dimension. | |
| Array< T, Alloc > | index (const Array< octave::idx_vector > &ia) const |
| Size of the specified dimension. | |
| Array< T, Alloc > | index (const octave::idx_vector &i, bool resize_ok, const T &rfv) const |
| Indexing with possible resizing and fill. | |
| Array< T, Alloc > | index (const octave::idx_vector &i, bool resize_ok) const |
| Size of the specified dimension. | |
| Array< T, Alloc > | index (const octave::idx_vector &i, const octave::idx_vector &j, bool resize_ok, const T &rfv) const |
| Size of the specified dimension. | |
| Array< T, Alloc > | index (const octave::idx_vector &i, const octave::idx_vector &j, bool resize_ok) const |
| Size of the specified dimension. | |
| Array< T, Alloc > | index (const Array< octave::idx_vector > &ia, bool resize_ok, const T &rfv) const |
| Size of the specified dimension. | |
| Array< T, Alloc > | index (const Array< octave::idx_vector > &ia, bool resize_ok) const |
| Size of the specified dimension. | |
| virtual T | resize_fill_value () const |
| Size of the specified dimension. | |
| void | resize2 (octave_idx_type nr, octave_idx_type nc, const T &rfv) |
| Resizing (with fill). | |
| void | resize2 (octave_idx_type nr, octave_idx_type nc) |
| Size of the specified dimension. | |
| void | resize1 (octave_idx_type n, const T &rfv) |
| Size of the specified dimension. | |
| void | resize1 (octave_idx_type n) |
| Size of the specified dimension. | |
| void | resize (const dim_vector &dv, const T &rfv) |
| Size of the specified dimension. | |
| void | resize (const dim_vector &dv) |
| Size of the specified dimension. | |
| void | assign (const octave::idx_vector &i, const Array< T, Alloc > &rhs, const T &rfv) |
| Indexed assignment (always with resize & fill). | |
| void | assign (const octave::idx_vector &i, const Array< T, Alloc > &rhs) |
| Size of the specified dimension. | |
| void | assign (const octave::idx_vector &i, const octave::idx_vector &j, const Array< T, Alloc > &rhs, const T &rfv) |
| Size of the specified dimension. | |
| void | assign (const octave::idx_vector &i, const octave::idx_vector &j, const Array< T, Alloc > &rhs) |
| Size of the specified dimension. | |
| void | assign (const Array< octave::idx_vector > &ia, const Array< T, Alloc > &rhs, const T &rfv) |
| Size of the specified dimension. | |
| void | assign (const Array< octave::idx_vector > &ia, const Array< T, Alloc > &rhs) |
| Size of the specified dimension. | |
| void | delete_elements (const octave::idx_vector &i) |
| Deleting elements. | |
| void | delete_elements (int dim, const octave::idx_vector &i) |
| A(:,...,I,...,:) = [] (>= 2 subscripts, one of them is non-colon) | |
| void | delete_elements (const Array< octave::idx_vector > &ia) |
| Dispatcher to the above two. | |
| Array< T, Alloc > & | insert (const Array< T, Alloc > &a, const Array< octave_idx_type > &idx) |
| Insert an array into another at a specified position. | |
| Array< T, Alloc > & | insert (const Array< T, Alloc > &a, octave_idx_type r, octave_idx_type c) |
| This is just a special case for idx = [r c 0 ...]. | |
| void | maybe_economize () |
| Size of the specified dimension. | |
| void | print_info (std::ostream &os, const std::string &prefix) const |
| Size of the specified dimension. | |
| Array< T, Alloc > | sort (int dim=0, sortmode mode=ASCENDING) const |
| Size of the specified dimension. | |
| Array< T, Alloc > | sort (Array< octave_idx_type > &sidx, int dim=0, sortmode mode=ASCENDING) const |
| Size of the specified dimension. | |
| sortmode | issorted (sortmode mode=UNSORTED) const |
| Ordering is auto-detected or can be specified. | |
| Array< octave_idx_type > | sort_rows_idx (sortmode mode=ASCENDING) const |
| Sort by rows returns only indices. | |
| sortmode | is_sorted_rows (sortmode mode=UNSORTED) const |
| Ordering is auto-detected or can be specified. | |
| octave_idx_type | lookup (const T &value, sortmode mode=UNSORTED) const |
| Do a binary lookup in a sorted array. | |
| Array< octave_idx_type > | lookup (const Array< T, Alloc > &values, sortmode mode=UNSORTED) const |
| Ditto, but for an array of values, specializing on the case when values are sorted. | |
| octave_idx_type | nnz () const |
| Count nonzero elements. | |
| Array< octave_idx_type > | find (octave_idx_type n=-1, bool backward=false) const |
| Find indices of (at most n) nonzero elements. | |
| Array< T, Alloc > | nth_element (const octave::idx_vector &n, int dim=0) const |
| Returns the n-th element in increasing order, using the same ordering as used for sort. | |
| Array< T, Alloc > | diag (octave_idx_type k=0) const |
| Get the kth super or subdiagonal. | |
| Array< T, Alloc > | diag (octave_idx_type m, octave_idx_type n) const |
| Size of the specified dimension. | |
| Array< U, A > | map (F fcn) const |
| Apply function fcn to each element of the Array<T, Alloc>. | |
| Array< U, A > | map (U(&fcn)(T)) const |
| Overloads for function references. | |
| Array< U, A > | map (U(&fcn)(const T &)) const |
| Size of the specified dimension. | |
| bool | test (F fcn) const |
| Generic any/all test functionality with arbitrary predicate. | |
| bool | test_any (F fcn) const |
| Simpler calls. | |
| bool | test_any (bool(&fcn)(T)) const |
| Overloads for function references. | |
| bool | test_any (bool(&fcn)(const T &)) const |
| Size of the specified dimension. | |
| bool | test_all (F fcn) const |
| Size of the specified dimension. | |
| bool | test_all (bool(&fcn)(T)) const |
| Size of the specified dimension. | |
| bool | test_all (bool(&fcn)(const T &)) const |
| Size of the specified dimension. | |
| bool | optimize_dimensions (const dim_vector &dv) |
| Returns true if this->dims () == dv, and if so, replaces this->m_dimensions by a shallow copy of dv. | |
Static Protected Member Functions inherited from Array< T > | |
| static Array< T, Alloc > | cat (int dim, octave_idx_type n, const Array< T, Alloc > *array_list) |
| Concatenation along a specified (0-based) dimension, equivalent to cat(). | |
Protected Attributes inherited from DiagArray2< T > | |
| octave_idx_type | m_d1 |
| octave_idx_type | m_d2 |
Protected Attributes inherited from Array< T > | |
| dim_vector | m_dimensions |
| Array< T, Alloc >::ArrayRep * | m_rep |
| T * | m_slice_data |
| octave_idx_type | m_slice_len |
Definition at line 37 of file fDiagMatrix.h.
Definition at line 41 of file fDiagMatrix.h.
|
default |
Referenced by abs().
|
default |
|
default |
|
inline |
Definition at line 51 of file fDiagMatrix.h.
|
inline |
Definition at line 54 of file fDiagMatrix.h.
|
inline |
Definition at line 57 of file fDiagMatrix.h.
|
inline |
Definition at line 60 of file fDiagMatrix.h.
Definition at line 62 of file fDiagMatrix.h.
|
inline |
Definition at line 64 of file fDiagMatrix.h.
| FloatDiagMatrix FloatDiagMatrix::abs | ( | ) | const |
Definition at line 128 of file fDiagMatrix.cc.
References FloatDiagMatrix(), abs(), DiagArray2< T >::columns(), extract_diag(), and DiagArray2< T >::rows().
Referenced by abs(), and octave_float_diag_matrix::map().
| FloatColumnVector FloatDiagMatrix::column | ( | char * | s | ) | const |
Definition at line 212 of file fDiagMatrix.cc.
References DiagArray2< T >::cols(), column(), and current_liboctave_error_handler.
| FloatColumnVector FloatDiagMatrix::column | ( | octave_idx_type | i | ) | const |
Definition at line 197 of file fDiagMatrix.cc.
References DiagArray2< T >::cols(), DiagArray2< T >::elem(), and DiagArray2< T >::rows().
Referenced by column().
| FloatDET FloatDiagMatrix::determinant | ( | ) | const |
Definition at line 309 of file fDiagMatrix.cc.
References DiagArray2< T >::cols(), DiagArray2< T >::elem(), len, DiagArray2< T >::length(), and DiagArray2< T >::rows().
Referenced by Fdet().
| FloatMatrix FloatDiagMatrix::extract | ( | octave_idx_type | r1, |
| octave_idx_type | c1, | ||
| octave_idx_type | r2, | ||
| octave_idx_type | c2 | ||
| ) | const |
Definition at line 146 of file fDiagMatrix.cc.
References Array< T, Alloc >::elem(), and DiagArray2< T >::elem().
|
inline |
Definition at line 108 of file fDiagMatrix.h.
References DiagArray2< T >::extract_diag().
Referenced by abs(), Fsvd(), octave_float_diag_matrix::map(), FloatComplexMatrix::pseudo_inverse(), FloatMatrix::pseudo_inverse(), rcond(), and octave_float_diag_matrix::save_binary().
| FloatDiagMatrix & FloatDiagMatrix::fill | ( | const FloatColumnVector & | a | ) |
Definition at line 76 of file fDiagMatrix.cc.
References Array< T, Alloc >::elem(), DiagArray2< T >::elem(), len, DiagArray2< T >::length(), and Array< T, Alloc >::numel().
| FloatDiagMatrix & FloatDiagMatrix::fill | ( | const FloatColumnVector & | a, |
| octave_idx_type | beg | ||
| ) |
Definition at line 102 of file fDiagMatrix.cc.
References Array< T, Alloc >::elem(), DiagArray2< T >::elem(), DiagArray2< T >::length(), and Array< T, Alloc >::numel().
| FloatDiagMatrix & FloatDiagMatrix::fill | ( | const FloatRowVector & | a | ) |
Definition at line 89 of file fDiagMatrix.cc.
References Array< T, Alloc >::elem(), DiagArray2< T >::elem(), len, DiagArray2< T >::length(), and Array< T, Alloc >::numel().
| FloatDiagMatrix & FloatDiagMatrix::fill | ( | const FloatRowVector & | a, |
| octave_idx_type | beg | ||
| ) |
Definition at line 115 of file fDiagMatrix.cc.
References Array< T, Alloc >::elem(), DiagArray2< T >::elem(), DiagArray2< T >::length(), and Array< T, Alloc >::numel().
| FloatDiagMatrix & FloatDiagMatrix::fill | ( | float | val | ) |
Definition at line 56 of file fDiagMatrix.cc.
References DiagArray2< T >::elem(), and DiagArray2< T >::length().
| FloatDiagMatrix & FloatDiagMatrix::fill | ( | float | val, |
| octave_idx_type | beg, | ||
| octave_idx_type | end | ||
| ) |
Definition at line 64 of file fDiagMatrix.cc.
References DiagArray2< T >::elem(), and DiagArray2< T >::length().
| FloatDiagMatrix FloatDiagMatrix::inverse | ( | ) | const |
Definition at line 227 of file fDiagMatrix.cc.
References inverse().
Referenced by Finv(), inverse(), FloatComplexMatrix::pseudo_inverse(), and FloatMatrix::pseudo_inverse().
| FloatDiagMatrix FloatDiagMatrix::inverse | ( | octave_idx_type & | info | ) | const |
Definition at line 234 of file fDiagMatrix.cc.
References DiagArray2< T >::cols(), DiagArray2< T >::elem(), len, DiagArray2< T >::length(), and DiagArray2< T >::rows().
| bool FloatDiagMatrix::operator!= | ( | const FloatDiagMatrix & | a | ) | const |
Definition at line 50 of file fDiagMatrix.cc.
|
default |
| bool FloatDiagMatrix::operator== | ( | const FloatDiagMatrix & | a | ) | const |
Definition at line 41 of file fDiagMatrix.cc.
References DiagArray2< T >::cols(), DiagArray2< T >::data(), DiagArray2< T >::length(), mx_inline_equal(), and DiagArray2< T >::rows().
| FloatDiagMatrix FloatDiagMatrix::pseudo_inverse | ( | float | tol = 0.0f | ) | const |
Definition at line 257 of file fDiagMatrix.cc.
References DiagArray2< T >::cols(), DiagArray2< T >::elem(), len, DiagArray2< T >::length(), and DiagArray2< T >::rows().
Referenced by Fpinv().
| float FloatDiagMatrix::rcond | ( | ) | const |
Definition at line 323 of file fDiagMatrix.cc.
References extract_diag(), Array< T, Alloc >::map(), FloatColumnVector::max(), and FloatColumnVector::min().
| FloatRowVector FloatDiagMatrix::row | ( | char * | s | ) | const |
Definition at line 182 of file fDiagMatrix.cc.
References current_liboctave_error_handler, row(), and DiagArray2< T >::rows().
| FloatRowVector FloatDiagMatrix::row | ( | octave_idx_type | i | ) | const |
Definition at line 167 of file fDiagMatrix.cc.
References DiagArray2< T >::cols(), DiagArray2< T >::elem(), and DiagArray2< T >::rows().
Referenced by row().
|
inline |
Definition at line 80 of file fDiagMatrix.h.
References MDiagArray2< T >::transpose().
|
friend |
Definition at line 140 of file fDiagMatrix.cc.
|
friend |
Definition at line 331 of file fDiagMatrix.cc.
|
friend |
Definition at line 134 of file fDiagMatrix.cc.