30 #ifndef SPARSELU_PANEL_DFS_H    31 #define SPARSELU_PANEL_DFS_H    37 template<
typename IndexVector>
    60 template <
typename Scalar, 
typename StorageIndex>
    61 template <
typename Traits>
    79     traits.mem_expand(panel_lsub, nextl_col, kmark);
    93       if (myfnz > kperm ) repfnz_col(krep) = kperm; 
   100       parent(krep) = oldrep; 
   101       repfnz_col(krep) = kperm; 
   103       Index maxdfs = xprune(krep); 
   109         while (xdfs < maxdfs) 
   123               panel_lsub(nextl_col++) = kchild;
   124               traits.mem_expand(panel_lsub, nextl_col, chmark);
   132               myfnz = repfnz_col(chrep); 
   137                   repfnz_col(chrep) = chperm; 
   144                 parent(krep) = oldrep; 
   145                 repfnz_col(krep) = chperm; 
   146                 xdfs = glu.
xlsub(krep); 
   147                 maxdfs = xprune(krep); 
   160         if(traits.update_segrep(krep,jj))
   173         maxdfs = xprune(krep); 
   218 template <
typename Scalar, 
typename StorageIndex>
   219 void SparseLUImpl<Scalar,StorageIndex>::panel_dfs(
const Index m, 
const Index w, 
const Index jcol, 
MatrixType& A, 
IndexVector& perm_r, 
Index& nseg, 
ScalarVector& dense, 
IndexVector& panel_lsub, 
IndexVector& segrep, 
IndexVector& repfnz, 
IndexVector& xprune, 
IndexVector& marker, 
IndexVector& parent, 
IndexVector& xplore, 
GlobalLU_t& glu)
   232     nextl_col = (jj - jcol) * m; 
   241       Index krow = it.row(); 
   242       dense_col(krow) = it.value();
   248       dfs_kernel(jj, perm_r, nseg, panel_lsub, segrep, repfnz_col, xprune, marker, parent,
   249                    xplore, glu, nextl_col, krow, 
traits);
   258 #endif // SPARSELU_PANEL_DFS_H 
A versatible sparse matrix representation. 
panel_dfs_traits(Index jcol, StorageIndex *marker)
void panel_dfs(const Index m, const Index w, const Index jcol, MatrixType &A, IndexVector &perm_r, Index &nseg, ScalarVector &dense, IndexVector &panel_lsub, IndexVector &segrep, IndexVector &repfnz, IndexVector &xprune, IndexVector &marker, IndexVector &parent, IndexVector &xplore, GlobalLU_t &glu)
Performs a symbolic factorization on a panel of columns [jcol, jcol+w) 
void mem_expand(IndexVector &, Index, Index)
IndexVector::Scalar StorageIndex
bool update_segrep(Index krep, StorageIndex jj)
Expression of a fixed-size or dynamic-size sub-vector. 
EIGEN_DEFAULT_DENSE_INDEX_TYPE Index
The Index type as used for the API. 
A matrix or vector expression mapping an existing expression. 
void dfs_kernel(const StorageIndex jj, IndexVector &perm_r, Index &nseg, IndexVector &panel_lsub, IndexVector &segrep, Ref< IndexVector > repfnz_col, IndexVector &xprune, Ref< IndexVector > marker, IndexVector &parent, IndexVector &xplore, GlobalLU_t &glu, Index &nextl_col, Index krow, Traits &traits)
The matrix class, also used for vectors and row-vectors.