29 #ifndef SPARSELU_COPY_TO_UCOL_H
30 #define SPARSELU_COPY_TO_UCOL_H
52 template <
typename Scalar,
typename StorageIndex>
56 Index ksub, krep, ksupno;
62 StorageIndex nextu = glu.
xusub(jcol);
63 Index kfnz, isub, segsize;
66 for (ksub = 0; ksub < nseg; ksub++) {
69 ksupno = glu.
supno(krep);
74 fsupc = glu.
xsup(ksupno);
75 isub = glu.
xlsub(fsupc) + kfnz - fsupc;
76 segsize = krep - kfnz + 1;
77 new_next = nextu + segsize;
78 while (new_next > glu.
nzumax) {
85 for (
i = 0;
i < segsize;
i++) {
86 irow = glu.
lsub(isub);
87 glu.
usub(nextu) = perm_r(irow);
88 glu.
ucol(nextu) = dense(irow);
99 glu.
xusub(jcol + 1) = nextu;
int i
Definition: BiCGSTAB_step_by_step.cpp:9
SCALAR Scalar
Definition: bench_gemm.cpp:45
A matrix or vector expression mapping an existing expression.
Definition: Ref.h:264
Index copy_to_ucol(const Index jcol, const Index nseg, IndexVector &segrep, BlockIndexVector repfnz, IndexVector &perm_r, BlockScalarVector dense, GlobalLU_t &glu)
Performs numeric block updates (sup-col) in topological order.
Definition: SparseLU_copy_to_ucol.h:53
char char char int int * k
Definition: level2_impl.h:374
@ USUB
Definition: SparseLU_Structs.h:77
@ UCOL
Definition: SparseLU_Structs.h:77
@ emptyIdxLU
Definition: SparseLU_Memory.h:41
Namespace containing all symbols from the Eigen library.
Definition: bench_norm.cpp:70
EIGEN_DEFAULT_DENSE_INDEX_TYPE Index
The Index type as used for the API.
Definition: Meta.h:83
Definition: Eigen_Colamd.h:49
Definition: SparseLU_Structs.h:80
IndexVector usub
Definition: SparseLU_Structs.h:91
IndexVector xsup
Definition: SparseLU_Structs.h:82
Index nzumax
Definition: SparseLU_Structs.h:93
Index num_expansions
Definition: SparseLU_Structs.h:95
IndexVector supno
Definition: SparseLU_Structs.h:83
IndexVector lsub
Definition: SparseLU_Structs.h:85
IndexVector xusub
Definition: SparseLU_Structs.h:92
IndexVector xlsub
Definition: SparseLU_Structs.h:87
ScalarVector ucol
Definition: SparseLU_Structs.h:90