41{
42 typedef typename ScalarVector::Scalar
Scalar;
43
44
45
46 Index isub = lptr + no_zeros;
49 for (i = 0; i < ((SegSizeAtCompileTime==
Dynamic)?segsize:SegSizeAtCompileTime); i++)
50 {
51 irow = lsub(isub);
52 tempv(i) = dense(irow);
53 ++isub;
54 }
55
56 luptr += lda * no_zeros + no_zeros;
57
58 Map<Matrix<Scalar,SegSizeAtCompileTime,SegSizeAtCompileTime, ColMajor>, 0, OuterStride<> > A( &(lusup.data()[luptr]), segsize, segsize, OuterStride<>(lda) );
59 Map<Matrix<Scalar,SegSizeAtCompileTime,1> > u(tempv.data(), segsize);
60
61 u = A.template triangularView<UnitLower>().solve(u);
62
63
64 luptr += segsize;
67 Map<Matrix<Scalar,Dynamic,SegSizeAtCompileTime, ColMajor>, 0, OuterStride<> > B( &(lusup.data()[luptr]), nrow, segsize, OuterStride<>(lda) );
70 Map<Matrix<Scalar,Dynamic,1>, 0, OuterStride<> > l(tempv.data()+segsize+aligned_offset+aligned_with_B_offset, nrow, OuterStride<>(ldl) );
71
72 l.setZero();
73 internal::sparselu_gemm<Scalar>(l.rows(), l.cols(), B.cols(), B.data(), B.outerStride(), u.data(), u.outerStride(), l.data(), l.outerStride());
74
75
76 isub = lptr + no_zeros;
77 for (i = 0; i < ((SegSizeAtCompileTime==
Dynamic)?segsize:SegSizeAtCompileTime); i++)
78 {
79 irow = lsub(isub++);
80 dense(irow) = tempv(i);
81 }
82
83
84 for (i = 0; i < nrow; i++)
85 {
86 irow = lsub(isub++);
87 dense(irow) -= l(i);
88 }
89}
Index first_multiple(Index size, Index base)
Definition Memory.h:476
static Index first_default_aligned(const DenseBase< Derived > &m)
Definition DenseCoeffsBase.h:646
EIGEN_DEFAULT_DENSE_INDEX_TYPE Index
The Index type as used for the API.
Definition Meta.h:33
const int Dynamic
Definition Constants.h:21
typename Traits< remove_cvref_t< L > >::Scalar Scalar
Definition Line.hpp:36
@ size
Definition GenericPacketMath.h:102