11 #ifndef EIGEN_SPARSELU_SUPERNODAL_MATRIX_H 12 #define EIGEN_SPARSELU_SUPERNODAL_MATRIX_H 32 template <
typename _Scalar,
typename _Index>
46 IndexVector& rowind_colptr, IndexVector& col_to_sup, IndexVector& sup_to_col )
48 setInfos(m, n, nzval, nzval_colptr, rowind, rowind_colptr, col_to_sup, sup_to_col);
61 void setInfos(Index m, Index n, ScalarVector& nzval, IndexVector& nzval_colptr, IndexVector& rowind,
62 IndexVector& rowind_colptr, IndexVector& col_to_sup, IndexVector& sup_to_col )
157 template<
typename Dest>
181 template<
typename Scalar,
typename Index>
190 m_startidval(m_idval),
201 inline Scalar value()
const {
return m_matrix.valuePtr()[m_idval]; }
205 inline Index index()
const {
return m_matrix.rowIndex()[m_idrow]; }
211 inline operator bool()
const 213 return ( (m_idval < m_endidval) && (m_idval >= m_startidval)
214 && (m_idrow < m_endidrow) );
232 template<
typename Scalar,
typename Index>
233 template<
typename Dest>
237 Index nrhs = X.cols();
247 Index nrow = nsupr - nsupc;
252 for (
Index j = 0; j < nrhs; j++)
259 X(irow, j) -= X(fsupc, j) * it.
value();
272 U = A.template triangularView<UnitLower>().solve(U);
276 work.block(0, 0, nrow, nrhs) = A * U;
279 for (
Index j = 0; j < nrhs; j++)
281 Index iptr = istart + nsupc;
282 for (
Index i = 0; i < nrow; i++)
285 X(irow, j) -= work(i, j);
298 #endif // EIGEN_SPARSELU_MATRIX_H
const Index * rowIndex() const
const Scalar * valuePtr() const
A matrix or vector expression mapping an existing array of data.
const Index * supToCol() const
const Index * rowIndexPtr() const
InnerIterator class to iterate over nonzero values of the current column in the supernodal matrix L...
InnerIterator & operator++()
~MappedSuperNodalMatrix()
const Index * colIndexPtr() const
Matrix< Scalar, Dynamic, 1 > ScalarVector
void setInfos(Index m, Index n, ScalarVector &nzval, IndexVector &nzval_colptr, IndexVector &rowind, IndexVector &rowind_colptr, IndexVector &col_to_sup, IndexVector &sup_to_col)
Matrix< _Scalar, _Rows, _Cols, _Options, _MaxRows, _MaxCols > & setZero(Index size)
EIGEN_STRONG_INLINE const Scalar * data() const
An InnerIterator allows to loop over the element of a sparse (or dense) matrix or expression...
MappedSuperNodalMatrix(Index m, Index n, ScalarVector &nzval, IndexVector &nzval_colptr, IndexVector &rowind, IndexVector &rowind_colptr, IndexVector &col_to_sup, IndexVector &sup_to_col)
void solveInPlace(MatrixBase< Dest > &X) const
Solve with the supernode triangular matrix.
Matrix< Index, Dynamic, 1 > IndexVector
const Index * colToSup() const
const MappedSuperNodalMatrix & m_matrix
Convenience specialization of Stride to specify only an outer stride See class Map for some examples...
a class to manipulate the L supernodal factor from the SparseLU factorization
Base class for all dense matrices, vectors, and expressions.
InnerIterator(const MappedSuperNodalMatrix &mat, Index outer)