/usr/include/trilinos/ml_Preconditioner.h is in libtrilinos-ml-dev 12.12.1-5.
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 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 | /*!
* \file ml_Preconditioner.h
*
* \class ML_Preconditioner
*
* \brief (Mostly) abstract base class wrapper for Epetra_Operator-based ML
* preconditioners. Implements a few Teuchos-related query functions.
*
* \date Last update to Doxygen: 13-Nov-06
*
*/
/* ******************************************************************** */
/* See the file COPYRIGHT for a complete copyright notice, contact */
/* person and disclaimer. */
/* ******************************************************************** */
#ifndef ML_PRECONDITIONER_H
#define ML_PRECONDITIONER_H
#if defined(HAVE_ML_EPETRA) && defined(HAVE_ML_TEUCHOS)
#include "Epetra_Comm.h"
#include "Epetra_Map.h"
#include "Epetra_Operator.h"
#include "Teuchos_ParameterList.hpp"
#include "ml_utils.h"
namespace ML_Epetra
{
class ML_Preconditioner: public virtual Epetra_Operator
{
public:
//! @name Constructor
//@{
//! Constructor
ML_Preconditioner():Label_(0),IsComputePreconditionerOK_(0){};
//@}
//! @name Destructor
//@{
//! Destructor
virtual ~ML_Preconditioner() {if(Label_) delete [] Label_;};
//@}
//@{ \name Query & Set functions
//! Prints label associated to this object.
virtual const char* Label() const{return(Label_);};
//! Prints unused parameters in the input ParameterList on standard output.
virtual void PrintUnused() const
{
List_.unused(std::cout);
}
//! Prints unused parameters in the input ParameterList on the specified stream.
virtual void PrintUnused(std::ostream & os) const
{
List_.unused(os);
}
//! Prints unused parameters in the input ParameterList to std::cout on proc \c MyPID.
/*! Mispelled parameters are simply ignored. Therefore, it is often the best
* choice to print out the parameters that have not been used in the
* construction phase.
* - \param MyPID (In) : ID of process that should print the unused parameters.
*/
virtual void PrintUnused(const int MyPID) const
{
if( Comm().MyPID() == MyPID ) {
ML_print_line("-",78);
std::cout << "Unused parameters:" << std::endl;
PrintUnused();
ML_print_line("-",78);
}
}
//! Gets a reference to the internally stored parameters' list.
virtual Teuchos::ParameterList& GetList()
{
return List_;
}
//! Prints on \c std::cout the values of the internally stored parameter list for processor \c MyPID
virtual void PrintList(int MyPID)
{
if( Comm().MyPID() == MyPID ) {
ML_print_line("-",78);
std::cout << List_;
ML_print_line("-",78);
}
}
//! Copies \c List into the internally stored parameter list object.
virtual int SetParameterList(const Teuchos::ParameterList& List)
{
if( IsComputePreconditionerOK_ == true ) DestroyPreconditioner();
List_ = List;
return 0;
}
//@}
//@{ \name Attribute access functions
//! Computes the multilevel hierarchy.
/*! Computes the multilevel hierarchy. This function retrives the user's defines parameters (as
specified in the input ParameterList), or takes default values otherwise, and creates the ML
objects for aggregation and hierarchy. Allocated data can be freed used DestroyPreconditioner(),
or by the destructor,
In a Newton-type procedure, several linear systems have to be solved, Often, these systems
are not too different. In this case, it might be convenient to keep the already
computed preconditioner (with hierarchy, coarse solver, smoothers), and use it to
precondition the next linear system. ML offers a way to determine whether the
already available preconditioner is "good enough" for the next linear system.
The user should proceed as follows:
- define \c "reuse: enable" == \c true
- solve the first linear system. ML tries to estimate the rate of convergence, and record it;
- change the values of the linear system matrix (but NOT its structure)
- compute the new preconditioner as \c ComputePreconditioner(true)
It is supposed that the pointer to the Epetra_RowMatrix remains constant. Currently,
it is not possible to modify this pointer (other than creating a new preconditioner) */
//! Computes the preconditioner
virtual int ComputePreconditioner(const bool CheckFiltering)=0;
//! Recomputes the preconditioner
virtual int ReComputePreconditioner()=0;
//! Print the individual operators in the multigrid hierarchy.
virtual void Print(int whichHierarchy=-2)=0;
//! Queries whether multilevel hierarchy has been computed or not.
virtual int IsPreconditionerComputed() const
{
return(IsComputePreconditionerOK_);
}
//! Destroys all structures allocated in \c ComputePreconditioner() if the preconditioner has been computed.
virtual int DestroyPreconditioner()=0;
//! Return operator complexity and #nonzeros in fine grid matrix.
virtual void Complexities(double &complexity, double &fineNnz)=0;
//@}
protected:
//@{ \name Internal data
//! Label for this object
char* Label_;
//! Specifies whether a hierarchy already exists or not.
bool IsComputePreconditionerOK_;
//! List containing all input parameters.
Teuchos::ParameterList List_;
//@}
};//ML_Preconditioner
}//end namespace ML_Epetra
#endif
#endif
|