aboutsummaryrefslogtreecommitdiffhomepage
path: root/Eigen/src/Eigenvalues/ComplexEigenSolver.h
diff options
context:
space:
mode:
authorGravatar Jitse Niesen <jitse@maths.leeds.ac.uk>2012-07-28 21:30:09 +0100
committerGravatar Jitse Niesen <jitse@maths.leeds.ac.uk>2012-07-28 21:30:09 +0100
commit696b2f999f1fde11ad5dc49282e7450c693ba6db (patch)
tree6f2532ac3cfbcbd2839ea3cbf964ec90af3e8ddd /Eigen/src/Eigenvalues/ComplexEigenSolver.h
parent6f54269829ce3bd13ea2f7a2e5d6d03b261c1cff (diff)
Eigenvalues module: Implement setMaxIterations() methods.
Diffstat (limited to 'Eigen/src/Eigenvalues/ComplexEigenSolver.h')
-rw-r--r--Eigen/src/Eigenvalues/ComplexEigenSolver.h46
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)
{