16 #ifndef ANASAZI_TRACEMIN_DAVIDSON_SOLMGR_HPP
17 #define ANASAZI_TRACEMIN_DAVIDSON_SOLMGR_HPP
42 namespace Experimental {
77 template<
class ScalarType,
class MV,
class OP>
126 return (solver->getCurSubspaceDim() == solver->getMaxSubspaceDim());
149 template <
class MagnitudeType,
class MV,
class OP>
154 typedef std::complex<MagnitudeType> ScalarType;
160 MagnitudeType::this_class_is_missing_a_specialization();
166 template<
class ScalarType,
class MV,
class OP>
171 maxRestarts_ = pl.
get(
"Maximum Restarts", 50);
173 "Anasazi::TraceMinDavidsonSolMgr::constructor(): \"Maximum Restarts\" must be strictly positive.");
175 this->useHarmonic_ = pl.
get(
"Use Harmonic Ritz Values",
false);
177 TEUCHOS_TEST_FOR_EXCEPTION(this->useHarmonic_ && problem->getM() != Teuchos::null, std::invalid_argument,
"Anasazi::TraceMinDavidsonSolMgr::constructor(): Harmonic Ritz values do not currently work with generalized eigenvalue problems. Please disable \"Use Harmonic Ritz Values\".");
180 this->blockSize_ = pl.
get(
"Block Size", 1);
182 "Anasazi::TraceMinDavidsonSolMgr::constructor(): \"Block Size\" must be strictly positive.");
184 this->numRestartBlocks_ = (int)std::ceil(this->problem_->getNEV() / this->blockSize_);
185 this->numRestartBlocks_ = pl.
get(
"Num Restart Blocks", this->numRestartBlocks_);
187 "Anasazi::TraceMinDavidsonSolMgr::constructor(): \"Num Restart Blocks\" must be strictly positive.");
189 this->numBlocks_ = pl.
get(
"Num Blocks", 3*this->numRestartBlocks_);
191 "Anasazi::TraceMinDavidsonSolMgr::constructor(): \"Num Blocks\" must be greater than 1. If you only wish to use one block, please use TraceMinSolMgr instead of TraceMinDavidsonSolMgr.");
194 "Anasazi::TraceMinDavidsonSolMgr::constructor(): \"Num Blocks\" must be strictly greater than \"Num Restart Blocks\".");
196 std::stringstream ss;
197 ss <<
"Anasazi::TraceMinDavidsonSolMgr::constructor(): Potentially impossible orthogonality requests. Reduce basis size (" <<
static_cast<ptrdiff_t
>(this->numBlocks_)*this->blockSize_ <<
") or locking size (" << this->maxLocked_ <<
") because " << static_cast<ptrdiff_t>(this->numBlocks_) <<
"*" << this->blockSize_ <<
" + " << this->maxLocked_ <<
" > " <<
MVT::GetGlobalLength(*this->problem_->getInitVec()) <<
".";
199 std::invalid_argument, ss.str());
202 "Anasazi::TraceMinDavidsonSolMgr: Not enough storage space for requested number of eigenpairs.");
208 template <
class ScalarType,
class MV,
class OP>
211 #ifdef ANASAZI_TEUCHOS_TIME_MONITOR
215 if ( numRestarts >= maxRestarts_ ) {
220 this->printer_->stream(
IterationDetails) <<
" Performing restart number " << numRestarts <<
" of " << maxRestarts_ << std::endl << std::endl;
222 TraceMinBaseState<ScalarType,MV> oldstate = solver->getState();
223 TraceMinBaseState<ScalarType,MV> newstate;
224 int newdim = this->numRestartBlocks_*this->blockSize_;
225 std::vector<int> indToCopy(newdim);
226 for(
int i=0; i<newdim; i++) indToCopy[i] = i;
230 if(this->useHarmonic_)
232 newstate.V = MVT::CloneView(*solver->getRitzVectors(),indToCopy);
233 newstate.curDim = newdim;
238 this->copyPartOfState (oldstate, newstate, indToCopy);
242 newstate.NEV = oldstate.NEV;
243 solver->initialize(newstate);
static ptrdiff_t GetGlobalLength(const MV &mv)
Return the number of rows in the given multivector mv.
This class defines the interface required by an eigensolver and status test class to compute solution...
T & get(const std::string &name, T def_value)
#define TEUCHOS_TEST_FOR_EXCEPTION(throw_exception_test, Exception, msg)
Virtual base class which defines basic traits for the operator type.
TraceMinDavidsonSolMgr(const Teuchos::RCP< Eigenproblem< ScalarType, MV, OP > > &problem, Teuchos::ParameterList &pl)
Basic constructor for TraceMinDavidsonSolMgr.
The Anasazi::TraceMinBaseSolMgr provides an abstract base class for the TraceMin series of solver man...
Anasazi's templated virtual class for providing routines for orthogonalization and orthonormalization...
TEUCHOS_DEPRECATED RCP< T > rcp(T *p, Dealloc_T dealloc, bool owns_mem)
Traits class which defines basic operations on multivectors.
Anasazi header file which uses auto-configuration information to include necessary C++ headers...
The Anasazi::TraceMinBaseSolMgr provides an abstract base class for the TraceMin series of solver man...
The Anasazi::TraceMinDavidsonSolMgr provides a flexible solver manager over the TraceMinDavidson eige...
This class implements a TraceMin-Davidson iteration for solving symmetric generalized eigenvalue prob...
Implementation of the TraceMin-Davidson method.
This is an abstract base class for the trace minimization eigensolvers.
Anasazi's templated pure virtual class for managing the sorting of approximate eigenvalues computed b...
Common interface of stopping criteria for Anasazi's solvers.