28#ifndef SPARSELU_RELAX_SNODE_H
29#define SPARSELU_RELAX_SNODE_H
32#include "./InternalHeaderCheck.h"
49template <
typename Scalar,
typename StorageIndex>
51 IndexVector& descendants, IndexVector& relax_end) {
56 for (
Index j = 0; j < n; j++) {
59 descendants(parent) += descendants(j) + 1;
63 for (
Index j = 0; j < n;) {
66 while (parent != n && descendants(parent) < relax_columns) {
71 relax_end(snode_start) = StorageIndex(j);
74 while (descendants(j) != 0 && j < n) j++;
Derived & setConstant(Index size, const Scalar &val)
Definition CwiseNullaryOp.h:363
Derived & setZero(Index size)
Definition CwiseNullaryOp.h:567
void relax_snode(const Index n, IndexVector &et, const Index relax_columns, IndexVector &descendants, IndexVector &relax_end)
Identify the initial relaxed supernodes.
Definition SparseLU_relax_snode.h:50
Namespace containing all symbols from the Eigen library.
Definition B01_Experimental.dox:1
EIGEN_DEFAULT_DENSE_INDEX_TYPE Index
The Index type as used for the API.
Definition Meta.h:82