71 jsupno = glu.supno(jcol);
78 for (ksub = 0; ksub < nseg; ksub++) {
81 ksupno = glu.supno(krep);
82 if (jsupno != ksupno) {
84 fsupc = glu.xsup(ksupno);
85 fst_col = (std::max)(fsupc, fpanelc);
89 d_fsupc = fst_col - fsupc;
91 luptr = glu.xlusup(fst_col) + d_fsupc;
92 lptr = glu.xlsub(fsupc) + d_fsupc;
95 kfnz = (std::max)(kfnz, fpanelc);
97 segsize = krep - kfnz + 1;
98 nsupc = krep - fst_col + 1;
99 nsupr = glu.xlsub(fsupc + 1) - glu.xlsub(fsupc);
100 nrow = nsupr - d_fsupc - nsupc;
101 Index lda = glu.xlusup(fst_col + 1) - glu.xlusup(fst_col);
105 no_zeros = kfnz - fst_col;
107 LU_kernel_bmod<1>::run(segsize, dense, tempv, glu.lusup, luptr, lda, nrow, glu.lsub, lptr, no_zeros);
109 LU_kernel_bmod<Dynamic>::run(segsize, dense, tempv, glu.lusup, luptr, lda, nrow, glu.lsub, lptr, no_zeros);
114 nextlu = glu.xlusup(jcol);
115 fsupc = glu.xsup(jsupno);
119 new_next = nextlu + glu.xlsub(fsupc + 1) - glu.xlsub(fsupc);
120 Index offset = internal::first_multiple<Index>(new_next, internal::packet_traits<Scalar>::size) - new_next;
121 if (offset) new_next += offset;
122 while (new_next > glu.nzlumax) {
123 mem = memXpand<ScalarVector>(glu.lusup, glu.nzlumax, nextlu, LUSUP, glu.num_expansions);
127 for (isub = glu.xlsub(fsupc); isub < glu.xlsub(fsupc + 1); isub++) {
128 irow = glu.lsub(isub);
129 glu.lusup(nextlu) = dense(irow);
130 dense(irow) =
Scalar(0.0);
135 glu.lusup.segment(nextlu, offset).setZero();
138 glu.xlusup(jcol + 1) = StorageIndex(nextlu);
146 fst_col = (std::max)(fsupc, fpanelc);
148 if (fst_col < jcol) {
151 d_fsupc = fst_col - fsupc;
153 lptr = glu.xlsub(fsupc) + d_fsupc;
154 luptr = glu.xlusup(fst_col) + d_fsupc;
155 nsupr = glu.xlsub(fsupc + 1) - glu.xlsub(fsupc);
156 nsupc = jcol - fst_col;
157 nrow = nsupr - d_fsupc - nsupc;
160 ufirst = glu.xlusup(jcol) + d_fsupc;
161 Index lda = glu.xlusup(jcol + 1) - glu.xlusup(jcol);
162 MappedMatrixBlock A(&(glu.lusup.data()[luptr]), nsupc, nsupc, OuterStride<>(lda));
163 VectorBlock<ScalarVector> u(glu.lusup, ufirst, nsupc);
164 u = A.template triangularView<UnitLower>().solve(u);
166 new (&A) MappedMatrixBlock(&(glu.lusup.data()[luptr + nsupc]), nrow, nsupc, OuterStride<>(lda));
167 VectorBlock<ScalarVector> l(glu.lusup, ufirst + nsupc, nrow);
168 l.noalias() -= A * u;