#include <GenEigsBase.h>
Public Member Functions | |
Index | compute (SortRule selection=SortRule::LargestMagn, Index maxit=1000, Scalar tol=1e-10, SortRule sorting=SortRule::LargestMagn) |
ComplexVector | eigenvalues () const |
ComplexMatrix | eigenvectors () const |
ComplexMatrix | eigenvectors (Index nvec) const |
CompInfo | info () const |
void | init () |
void | init (const Scalar *init_resid) |
Index | num_iterations () const |
Index | num_operations () const |
Protected Member Functions | |
virtual void | sort_ritzpair (SortRule sort_rule) |
Protected Attributes | |
ArnoldiFac | m_fac |
const Index | m_n |
const Index | m_ncv |
const Index | m_nev |
Index | m_niter |
Index | m_nmatop |
OpType & | m_op |
ComplexVector | m_ritz_est |
ComplexVector | m_ritz_val |
ComplexMatrix | m_ritz_vec |
Private Types | |
using | ArnoldiFac = Arnoldi< Scalar, ArnoldiOpType > |
using | ArnoldiOpType = ArnoldiOp< Scalar, OpType, BOpType > |
using | Array = Eigen::Array< Scalar, Eigen::Dynamic, 1 > |
using | BoolArray = Eigen::Array< bool, Eigen::Dynamic, 1 > |
using | Complex = std::complex< Scalar > |
using | ComplexMatrix = Eigen::Matrix< Complex, Eigen::Dynamic, Eigen::Dynamic > |
using | ComplexVector = Eigen::Matrix< Complex, Eigen::Dynamic, 1 > |
using | Index = Eigen::Index |
using | MapConstVec = Eigen::Map< const Vector > |
using | MapMat = Eigen::Map< Matrix > |
using | MapVec = Eigen::Map< Vector > |
using | Matrix = Eigen::Matrix< Scalar, Eigen::Dynamic, Eigen::Dynamic > |
using | Scalar = typename OpType::Scalar |
using | Vector = Eigen::Matrix< Scalar, Eigen::Dynamic, 1 > |
Private Member Functions | |
Index | nev_adjusted (Index nconv) |
Index | num_converged (const Scalar &tol) |
void | restart (Index k, SortRule selection) |
void | retrieve_ritzpair (SortRule selection) |
Static Private Member Functions | |
static bool | is_complex (const Complex &v) |
static bool | is_conj (const Complex &v1, const Complex &v2) |
Private Attributes | |
CompInfo | m_info |
BoolArray | m_ritz_conv |
This is the base class for general eigen solvers, mainly for internal use. It is kept here to provide the documentation for member functions of concrete eigen solvers such as GenEigsSolver and GenEigsRealShiftSolver.
Definition at line 38 of file GenEigsBase.h.
|
private |
Definition at line 56 of file GenEigsBase.h.
|
private |
Definition at line 55 of file GenEigsBase.h.
|
private |
Definition at line 45 of file GenEigsBase.h.
|
private |
Definition at line 46 of file GenEigsBase.h.
|
private |
Definition at line 51 of file GenEigsBase.h.
|
private |
Definition at line 52 of file GenEigsBase.h.
|
private |
Definition at line 53 of file GenEigsBase.h.
|
private |
Definition at line 42 of file GenEigsBase.h.
|
private |
Definition at line 49 of file GenEigsBase.h.
|
private |
Definition at line 47 of file GenEigsBase.h.
|
private |
Definition at line 48 of file GenEigsBase.h.
|
private |
Definition at line 43 of file GenEigsBase.h.
|
private |
Definition at line 41 of file GenEigsBase.h.
|
private |
Definition at line 44 of file GenEigsBase.h.
|
inline |
Conducts the major computation procedure.
selection | An enumeration value indicating the selection rule of the requested eigenvalues, for example SortRule::LargestMagn to retrieve eigenvalues with the largest magnitude. The full list of enumeration values can be found in Enumerations. |
maxit | Maximum number of iterations allowed in the algorithm. |
tol | Precision parameter for the calculated eigenvalues. |
sorting | Rule to sort the eigenvalues and eigenvectors. Supported values are SortRule::LargestMagn , SortRule::LargestReal , SortRule::LargestImag , SortRule::SmallestMagn , SortRule::SmallestReal and SortRule::SmallestImag , for example SortRule::LargestMagn indicates that eigenvalues with largest magnitude come first. Note that this argument is only used to sort the final result, and the selection rule (e.g. selecting the largest or smallest eigenvalues in the full spectrum) is specified by the parameter selection . |
Definition at line 417 of file GenEigsBase.h.
|
inline |
Returns the converged eigenvalues.
Eigen::Vector<std::complex<Scalar>, ...>
, depending on the template parameter Scalar
defined. Definition at line 466 of file GenEigsBase.h.
|
inline |
Returns all converged eigenvectors.
Definition at line 524 of file GenEigsBase.h.
|
inline |
Returns the eigenvectors associated with the converged eigenvalues.
nvec | The number of eigenvectors to return. |
Eigen::Matrix<std::complex<Scalar>, ...>
, depending on the template parameter Scalar
defined. Definition at line 496 of file GenEigsBase.h.
|
inline |
Returns the status of the computation. The full list of enumeration values can be found in Enumerations.
Definition at line 447 of file GenEigsBase.h.
|
inline |
Initializes the solver by providing a random initial residual vector.
This overloaded function generates a random initial residual vector (with a fixed random seed) for the algorithm. Elements in the vector follow independent Uniform(-0.5, 0.5) distribution.
Definition at line 386 of file GenEigsBase.h.
|
inline |
Initializes the solver by providing an initial residual vector.
init_resid | Pointer to the initial residual vector. |
Spectra (and also ARPACK) uses an iterative algorithm to find eigenvalues. This function allows the user to provide the initial residual vector.
Definition at line 358 of file GenEigsBase.h.
|
inlinestaticprivate |
Definition at line 82 of file GenEigsBase.h.
|
inlinestaticprivate |
Definition at line 83 of file GenEigsBase.h.
|
inlineprivate |
Definition at line 161 of file GenEigsBase.h.
|
inlineprivate |
Definition at line 141 of file GenEigsBase.h.
|
inline |
Returns the number of iterations used in the computation.
Definition at line 452 of file GenEigsBase.h.
|
inline |
Returns the number of matrix operations used in the computation.
Definition at line 457 of file GenEigsBase.h.
|
inlineprivate |
Definition at line 86 of file GenEigsBase.h.
|
inlineprivate |
Definition at line 196 of file GenEigsBase.h.
|
inlineprotectedvirtual |
Reimplemented in Spectra::GenEigsComplexShiftSolver< OpType >, and Spectra::GenEigsRealShiftSolver< OpType >.
Definition at line 261 of file GenEigsBase.h.
|
protected |
Definition at line 68 of file GenEigsBase.h.
|
private |
Definition at line 76 of file GenEigsBase.h.
|
protected |
Definition at line 62 of file GenEigsBase.h.
|
protected |
Definition at line 64 of file GenEigsBase.h.
|
protected |
Definition at line 63 of file GenEigsBase.h.
|
protected |
Definition at line 66 of file GenEigsBase.h.
|
protected |
Definition at line 65 of file GenEigsBase.h.
|
protected |
Definition at line 60 of file GenEigsBase.h.
|
private |
Definition at line 75 of file GenEigsBase.h.
|
protected |
Definition at line 72 of file GenEigsBase.h.
|
protected |
Definition at line 70 of file GenEigsBase.h.
|
protected |
Definition at line 71 of file GenEigsBase.h.