diff options
author | Jitse Niesen <jitse@maths.leeds.ac.uk> | 2012-07-28 21:30:09 +0100 |
---|---|---|
committer | Jitse Niesen <jitse@maths.leeds.ac.uk> | 2012-07-28 21:30:09 +0100 |
commit | 696b2f999f1fde11ad5dc49282e7450c693ba6db (patch) | |
tree | 6f2532ac3cfbcbd2839ea3cbf964ec90af3e8ddd /Eigen/src/Eigenvalues/ComplexEigenSolver.h | |
parent | 6f54269829ce3bd13ea2f7a2e5d6d03b261c1cff (diff) |
Eigenvalues module: Implement setMaxIterations() methods.
Diffstat (limited to 'Eigen/src/Eigenvalues/ComplexEigenSolver.h')
-rw-r--r-- | Eigen/src/Eigenvalues/ComplexEigenSolver.h | 46 |
1 files changed, 16 insertions, 30 deletions
diff --git a/Eigen/src/Eigenvalues/ComplexEigenSolver.h b/Eigen/src/Eigenvalues/ComplexEigenSolver.h index 39dfe2a0a..95c70aecb 100644 --- a/Eigen/src/Eigenvalues/ComplexEigenSolver.h +++ b/Eigen/src/Eigenvalues/ComplexEigenSolver.h @@ -208,27 +208,7 @@ template<typename _MatrixType> class ComplexEigenSolver * Example: \include ComplexEigenSolver_compute.cpp * Output: \verbinclude ComplexEigenSolver_compute.out */ - ComplexEigenSolver& compute(const MatrixType& matrix, bool computeEigenvectors = true) - { - return computeInternal(matrix, computeEigenvectors, false, 0); - } - - /** \brief Computes eigendecomposition with specified maximum number of iterations. - * - * \param[in] matrix Square matrix whose eigendecomposition is to be computed. - * \param[in] computeEigenvectors If true, both the eigenvectors and the - * eigenvalues are computed; if false, only the eigenvalues are - * computed. - * \param[in] maxIter Maximum number of iterations. - * \returns Reference to \c *this - * - * This method provides the same functionality as compute(const MatrixType&, bool) but it also allows the - * user to specify the maximum number of iterations to be used when computing the Schur decomposition. - */ - ComplexEigenSolver& compute(const MatrixType& matrix, bool computeEigenvectors, Index maxIter) - { - return computeInternal(matrix, computeEigenvectors, true, maxIter); - } + ComplexEigenSolver& compute(const MatrixType& matrix, bool computeEigenvectors = true); /** \brief Reports whether previous computation was successful. * @@ -240,6 +220,19 @@ template<typename _MatrixType> class ComplexEigenSolver return m_schur.info(); } + /** \brief Sets the maximum number of iterations allowed. */ + ComplexEigenSolver& setMaxIterations(Index maxIters) + { + m_schur.setMaxIterations(maxIters); + return *this; + } + + /** \brief Returns the maximum number of iterations. */ + Index getMaxIterations() + { + return m_schur.getMaxIterations(); + } + protected: EigenvectorType m_eivec; EigenvalueType m_eivalues; @@ -251,26 +244,19 @@ template<typename _MatrixType> class ComplexEigenSolver private: void doComputeEigenvectors(RealScalar matrixnorm); void sortEigenvalues(bool computeEigenvectors); - ComplexEigenSolver& computeInternal(const MatrixType& matrix, bool computeEigenvectors, - bool maxIterSpecified, Index maxIter); - }; template<typename MatrixType> ComplexEigenSolver<MatrixType>& -ComplexEigenSolver<MatrixType>::computeInternal(const MatrixType& matrix, bool computeEigenvectors, - bool maxIterSpecified, Index maxIter) +ComplexEigenSolver<MatrixType>::compute(const MatrixType& matrix, bool computeEigenvectors) { // this code is inspired from Jampack assert(matrix.cols() == matrix.rows()); // Do a complex Schur decomposition, A = U T U^* // The eigenvalues are on the diagonal of T. - if (maxIterSpecified) - m_schur.compute(matrix, computeEigenvectors, maxIter); - else - m_schur.compute(matrix, computeEigenvectors); + m_schur.compute(matrix, computeEigenvectors); if(m_schur.info() == Success) { |