![]() |
Prusa Slicer 2.6.0
|
A sparse direct LU factorization and solver based on the PARDISO library. More...
#include <src/eigen/Eigen/src/PardisoSupport/PardisoSupport.h>
Inheritance diagram for Eigen::PardisoLU< MatrixType >:
Collaboration diagram for Eigen::PardisoLU< MatrixType >:Public Types | |
| enum | |
| typedef Traits::MatrixType | MatrixType |
| typedef Traits::StorageIndex | StorageIndex |
| typedef SparseMatrix< Scalar, RowMajor, StorageIndex > | SparseMatrixType |
| typedef Matrix< Scalar, Dynamic, 1 > | VectorType |
| typedef Matrix< StorageIndex, 1, MatrixType::ColsAtCompileTime > | IntRowVectorType |
| typedef Matrix< StorageIndex, MatrixType::RowsAtCompileTime, 1 > | IntColVectorType |
| typedef Array< StorageIndex, 64, 1, DontAlign > | ParameterType |
Public Member Functions | |
| PardisoLU () | |
| PardisoLU (const MatrixType &matrix) | |
| Derived & | compute (const MatrixType &matrix) |
| Index | cols () const |
| Index | rows () const |
| ComputationInfo | info () const |
| Reports whether previous computation was successful. | |
| ParameterType & | pardisoParameterArray () |
| PardisoLU< MatrixType > & | analyzePattern (const MatrixType &matrix) |
| PardisoLU< MatrixType > & | factorize (const MatrixType &matrix) |
| void | _solve_impl (const MatrixBase< Rhs > &b, MatrixBase< Dest > &dest) const |
| void | _solve_impl (const MatrixBase< BDerived > &b, MatrixBase< XDerived > &x) const |
| void | _solve_impl (const SparseMatrixBase< Rhs > &b, SparseMatrixBase< Dest > &dest) const |
| template<typename Rhs > | |
| const Solve< Derived, Rhs > | solve (const MatrixBase< Rhs > &b) const |
| template<typename Rhs > | |
| const Solve< Derived, Rhs > | solve (const SparseMatrixBase< Rhs > &b) const |
Protected Types | |
| typedef PardisoImpl< PardisoLU > | Base |
| typedef Base::Scalar | Scalar |
| typedef Base::RealScalar | RealScalar |
| typedef internal::pardiso_traits< PardisoLU< MatrixType > > | Traits |
Protected Member Functions | |
| void | getMatrix (const MatrixType &matrix) |
| void | pardisoInit (int type) |
| void | pardisoRelease () |
| void | manageErrorCode (Index error) const |
| PardisoLU< MatrixType > & | derived () |
| const PardisoLU< MatrixType > & | derived () const |
Protected Attributes | |
| SparseMatrixType | m_matrix |
| ComputationInfo | m_info |
| bool | m_analysisIsOk |
| bool | m_factorizationIsOk |
| StorageIndex | m_type |
| StorageIndex | m_msglvl |
| void * | m_pt [64] |
| ParameterType | m_iparm |
| IntColVectorType | m_perm |
| Index | m_size |
| bool | m_isInitialized |
Friends | |
| class | PardisoImpl< PardisoLU< MatrixType > > |
A sparse direct LU factorization and solver based on the PARDISO library.
This class allows to solve for A.X = B sparse linear problems via a direct LU factorization using the Intel MKL PARDISO library. The sparse matrix A must be squared and invertible. The vectors or matrices X and B can be either dense or sparse.
By default, it runs in in-core mode. To enable PARDISO's out-of-core feature, set:
| _MatrixType | the type of the sparse matrix A, it must be a SparseMatrix<> |
\implsparsesolverconcept
|
protected |
|
inherited |
|
inherited |
|
inherited |
|
inherited |
|
protected |
|
protected |
|
inherited |
|
inherited |
|
protectedinherited |
|
inherited |
|
inherited |
|
inline |
References Eigen::PardisoLU< MatrixType >::pardisoInit(), and Eigen::PardisoImpl< Derived >::ScalarIsComplex.
Here is the call graph for this function:
|
inlineexplicit |
References Eigen::PardisoLU< MatrixType >::compute(), Eigen::PardisoLU< MatrixType >::pardisoInit(), and Eigen::PardisoImpl< Derived >::ScalarIsComplex.
Here is the call graph for this function:
|
inherited |
|
inherited |
|
inlineinherited |
|
inherited |
Performs a symbolic decomposition on the sparcity of matrix.
This function is particularly useful when solving for several problems having the same structure.
|
inlineinherited |
| Derived & Eigen::PardisoImpl< Derived >::compute | ( | const MatrixType & | matrix | ) |
Referenced by Eigen::PardisoLU< MatrixType >::PardisoLU().
Here is the caller graph for this function:
|
inlineprotectedinherited |
|
inlineprotectedinherited |
|
inherited |
Performs a numeric decomposition of matrix
The given matrix must has the same sparcity than the matrix on which the symbolic decomposition has been performed.
|
inlineprotected |
References Eigen::PardisoLU< MatrixType >::m_matrix, and Eigen::SparseMatrix< _Scalar, _Options, _StorageIndex >::makeCompressed().
Here is the call graph for this function:
|
inlineinherited |
Reports whether previous computation was successful.
Success if computation was succesful, NumericalIssue if the matrix appears to be negative.
|
inlineprotectedinherited |
|
inlineprotected |
Referenced by Eigen::PardisoLU< MatrixType >::PardisoLU(), and Eigen::PardisoLU< MatrixType >::PardisoLU().
Here is the caller graph for this function:
|
inlineinherited |
|
inlineprotectedinherited |
|
inlineinherited |
|
inlineinherited |
References Eigen::SparseSolverBase< Derived >::derived(), eigen_assert, and Eigen::SparseSolverBase< Derived >::m_isInitialized.
Referenced by igl::embree::bone_heat(), igl::Frame_field_deformer::compute_optimal_positions(), igl::eigs(), igl::copyleft::comiso::FrameInterpolator::interpolateSymmetric(), igl::slim::solve_weighted_arap(), and igl::copyleft::comiso::NRosyField::solveNoRoundings().
Here is the call graph for this function:
Here is the caller graph for this function:
|
inlineinherited |
|
friend |
|
protectedinherited |
|
protectedinherited |
|
mutableprotectedinherited |
|
mutableprotectedinherited |
|
mutableprotectedinherited |
|
mutableprotected |
Referenced by Eigen::PardisoLU< MatrixType >::getMatrix().
|
protectedinherited |
|
mutableprotectedinherited |
|
mutableprotectedinherited |
|
protectedinherited |
|
protectedinherited |