#include "ov.h"
#include "defun-dld.h"
#include "error.h"
#include "gripes.h"
#include "utils.h"
#include "oct-locbuf.h"
#include "ov-re-mat.h"
#include "ov-re-sparse.h"
#include "ov-cx-sparse.h"
#include "oct-sparse.h"
Go to the source code of this file.
|
#define | H_empty(H, h) ((h) == 0) |
|
#define | LEFT(i) (((i) << 1) + 1) |
|
#define | PARENT(i) (((i) - 1) >> 1) |
|
#define | Q_empty(Q, N, qh, qt) ((qh) == (qt)) |
|
#define | RIGHT(i) (((i) << 1) + 2) |
|
|
static octave_idx_type | calc_degrees (octave_idx_type N, const octave_idx_type *ridx, const octave_idx_type *cidx, octave_idx_type *D) |
|
static octave_idx_type | find_starting_node (octave_idx_type N, const octave_idx_type *ridx, const octave_idx_type *cidx, const octave_idx_type *ridx2, const octave_idx_type *cidx2, octave_idx_type *D, octave_idx_type start) |
|
OCTAVE_EXPORT octave_value_list | Fsymrcm (const octave_value_list &args, int) |
|
C OCTAVE_EXPORT octave_function * | Gsymrcm (const octave_shlib &shl, bool relative) |
|
static void | H_heapify_min (CMK_Node *A, octave_idx_type i, octave_idx_type size) |
|
static void | H_insert (CMK_Node *H, octave_idx_type &h, const CMK_Node &o) |
|
static CMK_Node | H_remove_min (CMK_Node *H, octave_idx_type &h, int reorg) |
|
static CMK_Node | Q_deq (CMK_Node *Q, octave_idx_type N, octave_idx_type &qh) |
|
static void | Q_enq (CMK_Node *Q, octave_idx_type N, octave_idx_type &qt, const CMK_Node &o) |
|
static void | transpose (octave_idx_type N, const octave_idx_type *ridx, const octave_idx_type *cidx, octave_idx_type *ridx2, octave_idx_type *cidx2) |
|
#define H_empty |
( |
|
H, |
|
|
|
h |
|
) |
| ((h) == 0) |
#define LEFT |
( |
|
i | ) |
(((i) << 1) + 1) |
#define PARENT |
( |
|
i | ) |
(((i) - 1) >> 1) |
#define Q_empty |
( |
|
Q, |
|
|
|
N, |
|
|
|
qh, |
|
|
|
qt |
|
) |
| ((qh) == (qt)) |
#define RIGHT |
( |
|
i | ) |
(((i) << 1) + 2) |
Definition at line 192 of file symrcm.cc.
References CMK_Node::deg, CMK_Node::dist, Array< T >::fortran_vec(), CMK_Node::id, N, OCTAVE_LOCAL_BUFFER, OCTAVE_QUIT, Q, Q_deq(), Q_empty, Q_enq(), r1, r2, Faddeeva::w(), and x.
Referenced by Gsymrcm().
Definition at line 438 of file symrcm.cc.
References arg(), B, calc_degrees(), octave_value::columns(), CMK_Node::deg, CMK_Node::dist, Array< T >::elem(), error_state, find_starting_node(), Array< T >::fortran_vec(), gripe_square_matrix_required(), H_empty, H_insert(), H_remove_min(), CMK_Node::id, octave_value::is_real_type(), octave_value::length(), N, OCTAVE_LOCAL_BUFFER, OCTAVE_QUIT, octave_value(), print_usage(), Q, Q_deq(), Q_empty, Q_enq(), r1, r2, octave_value::rows(), octave_value::sparse_complex_matrix_value(), octave_value::sparse_matrix_value(), transpose(), Faddeeva::w(), Sparse< T >::xcidx(), and Sparse< T >::xridx().
Definition at line 382 of file symrcm.cc.
References N, OCTAVE_LOCAL_BUFFER, OCTAVE_QUIT, and Faddeeva::w().
Referenced by Sparse< T >::assign(), Sparse< T >::delete_elements(), Fqz(), Gsymbfact(), Gsymrcm(), SparseMatrix::hermitian(), Sparse< T >::index(), install_b_b_ops(), install_bm_bm_ops(), install_cdm_cdm_ops(), install_cell_ops(), install_chm_ops(), install_class_ops(), install_cm_cm_ops(), install_cs_cs_ops(), install_data_fcns(), install_dm_dm_ops(), install_fcdm_fcdm_ops(), install_fcm_fcm_ops(), install_fcs_fcs_ops(), install_fdm_fdm_ops(), install_fm_fm_ops(), install_fs_fs_ops(), install_m_m_ops(), install_pm_pm_ops(), install_range_ops(), install_s_s_ops(), install_sbm_sbm_ops(), install_scm_scm_ops(), install_sm_sm_ops(), install_str_str_ops(), install_struct_ops(), and Sparse< T >::permute().