/usr/include/trilinos/AztecOO_StatusTest.h is in libtrilinos-dev 10.4.0.dfsg-1ubuntu2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 | /*@HEADER
// ***********************************************************************
//
// AztecOO: An Object-Oriented Aztec Linear Solver Package
// Copyright (2002) Sandia Corporation
//
// Under terms of Contract DE-AC04-94AL85000, there is a non-exclusive
// license for use of this work by or on behalf of the U.S. Government.
//
// This library is free software; you can redistribute it and/or modify
// it under the terms of the GNU Lesser General Public License as
// published by the Free Software Foundation; either version 2.1 of the
// License, or (at your option) any later version.
//
// This library is distributed in the hope that it will be useful, but
// WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
// Lesser General Public License for more details.
//
// You should have received a copy of the GNU Lesser General Public
// License along with this library; if not, write to the Free Software
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
// USA
// Questions? Contact Michael A. Heroux (maherou@sandia.gov)
//
// ***********************************************************************
//@HEADER
*/
#ifndef AZTECOO_STATUSTEST_H
#define AZTECOO_STATUSTEST_H
class Epetra_MultiVector;
#include "AztecOO_StatusType.h"
#include "Epetra_ConfigDefs.h"
#include <iomanip>
//! AztecOO_StatusTest: A pure virtual class for extending the status testing capabilities of AztecOO.
/* AztecOO_StatusTest is an interface that can be implemented to extend the convergence testing
capabilities of AztecOO. Almost any kind of test can be expressed using this mechanism,
including composite tests. In this situation, two existing AztecOO_StatusTest objects
test1 and test2 can be used to create a new test. See AztecOO_StatusTestCombo for details
\warning Presently it is not valid to associate one status test instance with two different AztecOO objects.
*/
class AztecOO_StatusTest {
public:
//@{ \name Constructors/destructors.
//! Constructor
AztecOO_StatusTest() {};
//! Destructor
virtual ~AztecOO_StatusTest() {};
//@}
//@{ \name Methods that must be implemented by any AztecOO_StatusTest implementation.
//! Indicates if residual vector is required by this convergence test.
/*! If this method returns true, then the ResidualVector argument to the Converged() method will
defined. If this method returns false, then the ResidualVector may not be defined when Converged() is
called. Some iterative methods do not explicitly construct the residual vector at each iteration. Thus,
if this vector is not required, this vector will not need to be constructed if this method returns false.
*/
virtual bool ResidualVectorRequired() const = 0;
//! Check convergence status: Unconverged, Converged, Failed.
/*! This method checks to see if the convergence criteria are met. The calling routine may pass in the
current native residual vector (the one naturally produced as part of the iterative method) or a
pre-computed estimate of the two-norm of the current residual, or both or neither. The calling routine
should also indicate if the solution of the linear problem has been updated to be compatible with
the residual. Some methods, such as GMRES do update the solution at each iteration.
\param CurrentIter (In) Current iteration of iterative method.
\param CurrentResVector (In) The current residuals of the iterative process. These values are
assumed to be the residuals that are a "natural" by-product of the iterative process.
Typically this means they are not explicitly generated and are therefore subject to round-off
error. These values will also reflect the influence of any Any rigorous use of stopping criteria
should not
rely solely on results using this vector. Instead, tests can be performed using this vector
and, after convergence
is reached with this vector.
\param CurrentResNormEst (In) If the iterative method can cheaply provide this estimate,
as an alternative
or in addition to providing the CurrentResVector, this value will contain that estimate.
The value will be
set to -1.0 if no estimate is available.
\param SolutionUpdated (In) If this argument is true, then the solution vector that is part
of the Epetra_LinearProblem
object being solved is consistent with the residual. Some iterative methods do not keep the
solution vector
updated with the residual at each iteration. For example GMRES does not generate the solution
until the least-
square problem is solved at the end of the Arnoldi process.
\return AztecOO_StatusType: Unconverged, Converged or Failed.
*/
virtual AztecOO_StatusType CheckStatus(int CurrentIter, Epetra_MultiVector * CurrentResVector,
double CurrentResNormEst,
bool SolutionUpdated) = 0;
//! Return the result of the most recent checkStatus call
virtual AztecOO_StatusType GetStatus() const = 0;
//! Output formatted description of stopping test to output stream.
virtual ostream& Print(ostream& stream, int indent = 0) const = 0;
//@}
virtual void PrintStatus(ostream& os, AztecOO_StatusType type) const {
os << std::setiosflags(std::ios::left) << std::setw(13) << std::setfill('.');
switch (type) {
case Failed:
os << "Failed";
break;
case Converged:
os << "Converged";
break;
case Unconverged:
default:
os << "**";
break;
}
os << std::setiosflags(std::ios::right) << std::setfill(' ');
return;
}
};
#endif /* AZTECOO_STATUSTEST_H */
|