11 #ifndef BELOS_STATUS_TEST_LOGRESNORM_HPP
12 #define BELOS_STATUS_TEST_LOGRESNORM_HPP
34 template <
class ScalarType,
class MV,
class OP>
94 const std::vector<typename Teuchos::ScalarTraits<ScalarType>::magnitudeType>&
103 void print(std::ostream& os,
int indent = 0)
const;
116 std::ostringstream oss;
133 std::vector<typename Teuchos::ScalarTraits<ScalarType>::magnitudeType>
logResNorm_;
139 template <
class ScalarType,
class MV,
class OP>
145 maxIters_ = maxIters;
147 logResNorm_.reserve( maxIters_ );
152 template <
class ScalarType,
class MV,
class OP>
158 int numRHS = MVT::GetNumberVecs( *(lp.
getRHS()) );
162 if ( (numRHS==1) && (blkSize==1) && (currIters!=nIters_) )
164 std::vector<MagnitudeType> tmp_resvector( 1 );
169 MVT::MvNorm (*residMV, tmp_resvector,
TwoNorm);
172 logResNorm_.push_back( tmp_resvector[0] );
179 template <
class ScalarType,
class MV,
class OP>
184 logResNorm_.reserve( maxIters_ );
187 template <
class ScalarType,
class MV,
class OP>
190 for (
int j = 0; j < indent; j ++)
193 os <<
"Logging Absolute Residual 2-Norm" << std::endl;
196 template <
class ScalarType,
class MV,
class OP>
199 os << std::left << std::setw(13) << std::setfill(
'.');
201 os << std::left << std::setfill(
' ');
virtual Teuchos::RCP< const MV > getNativeResiduals(std::vector< typename Teuchos::ScalarTraits< ScalarType >::magnitudeType > *norms) const =0
Get the residuals native to the solver.
void setMaxIters(int maxIters)
Sets the maximum number of iterations allowed so internal storage can be resized. ...
StatusTestLogResNorm(int maxIters)
Constructor.
std::vector< typename Teuchos::ScalarTraits< ScalarType >::magnitudeType > logResNorm_
Log of absolute residual norm.
void print(std::ostream &os, int indent=0) const
Output formatted description of stopping test to output stream.
Pure virtual base class for defining the status testing capabilities of Belos.
const std::vector< typename Teuchos::ScalarTraits< ScalarType >::magnitudeType > & getLogResNorm() const
Returns the log of the absolute residual norm from the iteration.
StatusType getStatus() const
Return the result of the most recent CheckStatus call.
void printStatus(std::ostream &os, StatusType type) const
Print message for each status specific to this stopping test.
A Belos::StatusTest debugging class for storing the absolute residual norms generated during a solve...
Teuchos::RCP< const MV > getRHS() const
A pointer to the right-hand side B.
A pure virtual class for defining the status tests for the Belos iterative solvers.
int getNumIters() const
Returns the current number of iterations from the most recent StatusTest call.
StatusType
Whether the StatusTest wants iteration to stop.
Traits class which defines basic operations on multivectors.
int nIters_
Current number of iterations.
Teuchos::ScalarTraits< ScalarType >::magnitudeType MagnitudeType
The type of the magnitude (absolute value) of a ScalarType.
const std::vector< int > & getLSIndex() const
(Zero-based) indices of the linear system(s) currently being solved.
int maxIters_
Maximum number of iterations allowed.
std::string description() const
Method to return description of the debugging status test.
bool is_null(const RCP< T > &p)
StatusType checkStatus(Iteration< ScalarType, MV, OP > *iSolver)
Check convergence status of the iterative solver: Unconverged, Converged, Failed. ...
virtual int getNumIters() const =0
Get the current iteration count.
A linear system to solve, and its associated information.
virtual ~StatusTestLogResNorm()
Destructor.
MultiVecTraits< ScalarType, MV > MVT
virtual const LinearProblem< ScalarType, MV, OP > & getProblem() const =0
Get a constant reference to the linear problem.
int getMaxIters() const
Returns the maximum number of iterations set in the constructor.
void reset()
Resets the status test to the initial internal state.