|
MueLu Version of the Day
|
#include <MueLu_Ifpack2Smoother_decl.hpp>
Public Member Functions | |
| Ifpack2Smoother (const std::string &type, const Teuchos::ParameterList ¶mList=Teuchos::ParameterList(), const LocalOrdinal &overlap=0) | |
| virtual | ~Ifpack2Smoother () |
| void | SetParameterList (const Teuchos::ParameterList ¶mList) |
| Set parameters from a parameter list and return with default values. | |
| void | DeclareInput (Level ¤tLevel) const |
| Input. | |
| void | Setup (Level ¤tLevel) |
| void | Apply (MultiVector &X, const MultiVector &B, bool InitialGuessIsZero=false) const |
| Apply smoother. | |
| RCP< SmootherPrototype > | Copy () const |
| std::string | description () const |
| Return a simple one-line description of this object. | |
| void | print (Teuchos::FancyOStream &out, const VerbLevel verbLevel=Default) const |
| size_t | getNodeSmootherComplexity () const |
| Get a rough estimate of cost per iteration. | |
Public Member Functions inherited from MueLu::SmootherPrototype< double, int, int, Xpetra::EpetraNode > | |
| SmootherPrototype () | |
| @nameConstructors/Destructors. | |
| virtual | ~SmootherPrototype () |
| virtual void | CallBuild (Level &) const |
| virtual void | CallDeclareInput (Level &requestedLevel) const |
| bool | IsSetup () const |
| Get the state of a smoother prototype. | |
| void | IsSetup (bool const &ToF) |
| Set the state of a smoother prototype. | |
Public Member Functions inherited from MueLu::SmootherBase< double, int, int, Xpetra::EpetraNode > | |
| SmootherBase () | |
| virtual | ~SmootherBase () |
| void | declareConstructionOutcome (bool fail, std::string msg) |
| bool | constructionSuccessful () |
| std::string | constructionErrorMsg () |
| virtual | ~BaseClass () |
| Destructor. | |
| VerboseObject () | |
| virtual | ~VerboseObject () |
| Destructor. | |
| VerbLevel | GetVerbLevel () const |
| Get the verbosity level. | |
| void | SetVerbLevel (const VerbLevel verbLevel) |
| Set the verbosity level of this object. | |
| int | GetProcRankVerbose () const |
| Get proc rank used for printing. Do not use this information for any other purpose. | |
| int | SetProcRankVerbose (int procRank) const |
| Set proc rank used for printing. | |
| bool | IsPrint (MsgType type, int thisProcRankOnly=-1) const |
| Find out whether we need to print out information for a specific message type. | |
| Teuchos::FancyOStream & | GetOStream (MsgType type, int thisProcRankOnly=0) const |
| Get an output stream for outputting the input message type. | |
| Teuchos::FancyOStream & | GetBlackHole () const |
Public Member Functions inherited from MueLu::Describable | |
| virtual | ~Describable () |
| Destructor. | |
| virtual void | describe (Teuchos::FancyOStream &out_arg, const VerbLevel verbLevel=Default) const |
| void | describe (Teuchos::FancyOStream &out, const Teuchos::EVerbosityLevel verbLevel=Teuchos::Describable::verbLevel_default) const |
| Print the object with some verbosity level to an FancyOStream object. | |
| virtual std::string | ShortClassName () const |
| Return the class name of the object, without template parameters and without namespace. | |
Public Member Functions inherited from MueLu::Factory | |
| Factory () | |
| Constructor. | |
| virtual | ~Factory () |
| Destructor. | |
| virtual void | SetFactory (const std::string &varName, const RCP< const FactoryBase > &factory) |
| Configuration. | |
| const RCP< const FactoryBase > | GetFactory (const std::string &varName) const |
| Default implementation of FactoryAcceptor::GetFactory() | |
| RCP< ParameterList > | RemoveFactoriesFromList (const ParameterList &list) const |
| virtual RCP< const ParameterList > | GetValidParameterList () const |
| Return a const parameter list of valid parameters that setParameterList() will accept. | |
| void | EnableMultipleCallCheck () const |
| void | DisableMultipleCallCheck () const |
| void | ResetDebugData () const |
Public Member Functions inherited from MueLu::FactoryBase | |
| FactoryBase () | |
| Constructor. | |
| virtual | ~FactoryBase () |
| Destructor. | |
| int | GetID () const |
| return unique factory id | |
Public Member Functions inherited from MueLu::FactoryAcceptor | |
| virtual | ~FactoryAcceptor () |
Public Member Functions inherited from MueLu::ParameterListAcceptorImpl | |
| ParameterListAcceptorImpl () | |
| virtual | ~ParameterListAcceptorImpl ()=default |
| virtual const Teuchos::ParameterList & | GetParameterList () const |
| void | SetParameter (const std::string &name, const ParameterEntry &entry) |
| Set a parameter directly as a ParameterEntry. | |
| const ParameterEntry & | GetParameter (const std::string &name) const |
| Retrieves a const entry with the name name. | |
| virtual void | GetDocumentation (std::ostream &os) const |
| ParameterListAcceptor () | |
| virtual | ~ParameterListAcceptor ()=default |
Private Types | |
| typedef double | Scalar |
| typedef int | LocalOrdinal |
| typedef int | GlobalOrdinal |
| typedef Xpetra::EpetraNode | Node |
Private Member Functions | |
| void | SetPrecParameters (const Teuchos::ParameterList &list=Teuchos::ParameterList()) const |
Friends | |
| template<class Scalar2, class LocalOrdinal2, class GlobalOrdinal2, class Node2> | |
| class | Ifpack2Smoother |
Constructors / destructors | |
| class | Ifpack2Smoother |
| Constructor. | |
| Ifpack2Smoother (const std::string &type, const Teuchos::ParameterList ¶mList=Teuchos::ParameterList(), const LO &overlap=0) | |
| virtual | ~Ifpack2Smoother () |
| Destructor. | |
| void | SetParameterList (const Teuchos::ParameterList ¶mList) |
| Set parameters from a parameter list and return with default values. | |
| void | DeclareInput (Level ¤tLevel) const |
| Input. | |
Computational methods. | |
| void | Setup (Level ¤tLevel) |
| Set up the smoother. | |
| void | Apply (MultiVector &X, const MultiVector &B, bool InitialGuessIsZero=false) const |
| Apply the preconditioner. | |
Utilities | |
| RCP< SmootherPrototype > | Copy () const |
Overridden from Teuchos::Describable | |
| std::string | description () const |
| Return a simple one-line description of this object. | |
| void | print (Teuchos::FancyOStream &out, const VerbLevel verbLevel=Default) const |
| Print the object with some verbosity level to an FancyOStream object. | |
| RCP< Ifpack2::Preconditioner< double, int, int, Xpetra::EpetraNode > > | getPreconditioner () |
| For diagnostic purposes. | |
| size_t | getNodeSmootherComplexity () const |
| Get a rough estimate of cost per iteration. | |
| void | SetPrecParameters (const Teuchos::ParameterList &list=Teuchos::ParameterList()) const |
| void | SetupSchwarz (Level ¤tLevel) |
| void | SetupChebyshev (Level ¤tLevel) |
| void | SetupLineSmoothing (Level ¤tLevel) |
| void | SetupBlockRelaxation (Level ¤tLevel) |
| void | SetupTopological (Level ¤tLevel) |
| void | SetupAggregate (Level ¤tLevel) |
| void | SetupHiptmair (Level ¤tLevel) |
| void | SetupGeneric (Level ¤tLevel) |
| double | SetupChebyshevEigenvalues (Level ¤tLevel, const std::string &matrixName, const std::string &label, Teuchos::ParameterList ¶mList) const |
| bool | constructionSuccessful_ |
| std::string | type_ |
| ifpack2-specific key phrase that denote smoother type | |
| LO | overlap_ |
| overlap when using the smoother in additive Schwarz mode | |
| RCP< Ifpack2::Preconditioner< double, int, int, Xpetra::EpetraNode > > | prec_ |
| pointer to Ifpack2 preconditioner object | |
| RCP< Operator > | A_ |
| matrix, used in apply if solving residual equation | |
Additional Inherited Members | |
Public Types inherited from MueLu::SmootherPrototype< double, int, int, Xpetra::EpetraNode > | |
| typedef double | scalar_type |
| typedef int | local_ordinal_type |
| typedef int | global_ordinal_type |
| typedef Xpetra::EpetraNode | node_type |
Public Types inherited from MueLu::SmootherBase< double, int, int, Xpetra::EpetraNode > | |
| typedef double | scalar_type |
| typedef int | local_ordinal_type |
| typedef int | global_ordinal_type |
| typedef Xpetra::EpetraNode | node_type |
| static void | SetDefaultVerbLevel (const VerbLevel defaultVerbLevel) |
| Set the default (global) verbosity level. | |
| static VerbLevel | GetDefaultVerbLevel () |
| Get the default (global) verbosity level. | |
| static void | SetMueLuOStream (const Teuchos::RCP< Teuchos::FancyOStream > &mueluOStream) |
| static void | SetMueLuOFileStream (const std::string &filename) |
| static Teuchos::RCP< Teuchos::FancyOStream > | GetMueLuOStream () |
Static Public Member Functions inherited from MueLu::Factory | |
| static void | EnableTimerSync () |
| static void | DisableTimerSync () |
| static void | EnableMultipleCheckGlobally () |
| static void | DisableMultipleCheckGlobally () |
Protected Member Functions inherited from MueLu::Factory | |
| void | Input (Level &level, const std::string &varName) const |
| void | Input (Level &level, const std::string &varName, const std::string &varParamName) const |
| template<class T> | |
| T | Get (Level &level, const std::string &varName) const |
| template<class T> | |
| T | Get (Level &level, const std::string &varName, const std::string &varParamName) const |
| template<class T> | |
| void | Set (Level &level, const std::string &varName, const T &data) const |
| bool | IsAvailable (Level &level, const std::string &varName) const |
Static Protected Attributes inherited from MueLu::Factory | |
| static bool | timerSync_ = false |
Definition at line 247 of file MueLu_Ifpack2Smoother_decl.hpp.
|
private |
Definition at line 248 of file MueLu_Ifpack2Smoother_decl.hpp.
|
private |
Definition at line 249 of file MueLu_Ifpack2Smoother_decl.hpp.
|
private |
Definition at line 250 of file MueLu_Ifpack2Smoother_decl.hpp.
|
private |
Definition at line 251 of file MueLu_Ifpack2Smoother_decl.hpp.
|
inline |
Definition at line 262 of file MueLu_Ifpack2Smoother_decl.hpp.
|
inlinevirtual |
Definition at line 266 of file MueLu_Ifpack2Smoother_decl.hpp.
| MueLu::Ifpack2Smoother< double, int, int, Xpetra::EpetraNode >::Ifpack2Smoother | ( | const std::string & | type, |
| const Teuchos::ParameterList & | paramList = Teuchos::ParameterList(), | ||
| const LO & | overlap = 0 ) |
Definition at line 144 of file MueLu_Ifpack2Smoother_def.hpp.
|
inlinevirtual |
Destructor.
Definition at line 147 of file MueLu_Ifpack2Smoother_decl.hpp.
|
inlinevirtual |
Set parameters from a parameter list and return with default values.
Reimplemented from MueLu::ParameterListAcceptorImpl.
Definition at line 268 of file MueLu_Ifpack2Smoother_decl.hpp.
|
inlinevirtual |
Input.
Implements MueLu::SmootherPrototype< double, int, int, Xpetra::EpetraNode >.
Definition at line 269 of file MueLu_Ifpack2Smoother_decl.hpp.
|
inlinevirtual |
Implements MueLu::SmootherPrototype< double, int, int, Xpetra::EpetraNode >.
Definition at line 270 of file MueLu_Ifpack2Smoother_decl.hpp.
|
inlinevirtual |
Apply smoother.
Implements MueLu::SmootherBase< double, int, int, Xpetra::EpetraNode >.
Definition at line 271 of file MueLu_Ifpack2Smoother_decl.hpp.
|
inlinevirtual |
Implements MueLu::SmootherPrototype< double, int, int, Xpetra::EpetraNode >.
Definition at line 272 of file MueLu_Ifpack2Smoother_decl.hpp.
|
inlinevirtual |
Return a simple one-line description of this object.
Reimplemented from MueLu::Describable.
Definition at line 274 of file MueLu_Ifpack2Smoother_decl.hpp.
|
inline |
Definition at line 275 of file MueLu_Ifpack2Smoother_decl.hpp.
|
inlinevirtual |
Get a rough estimate of cost per iteration.
Implements MueLu::SmootherBase< double, int, int, Xpetra::EpetraNode >.
Definition at line 278 of file MueLu_Ifpack2Smoother_decl.hpp.
|
inlineprivate |
Definition at line 281 of file MueLu_Ifpack2Smoother_decl.hpp.
|
virtual |
Set parameters from a parameter list and return with default values.
Reimplemented from MueLu::ParameterListAcceptorImpl.
Definition at line 151 of file MueLu_Ifpack2Smoother_def.hpp.
|
virtual |
Input.
Implements MueLu::SmootherPrototype< double, int, int, Xpetra::EpetraNode >.
Definition at line 156 of file MueLu_Ifpack2Smoother_def.hpp.
|
virtual |
Set up the smoother.
This creates the underlying Ifpack2 smoother object, copies any parameter list options supplied to the constructor to the Ifpack2 object, and computes the preconditioner.
TODO The eigenvalue estimate should come from A_, not the Ifpack2 parameter list.
Implements MueLu::SmootherPrototype< double, int, int, Xpetra::EpetraNode >.
Definition at line 170 of file MueLu_Ifpack2Smoother_def.hpp.
|
virtual |
Apply the preconditioner.
Solves the linear system AX=B using the constructed smoother.
| X | initial guess |
| B | right-hand side |
| InitialGuessIsZero | (optional) If false, some work can be avoided. Whether this actually saves any work depends on the underlying Ifpack2 implementation. |
Implements MueLu::SmootherBase< double, int, int, Xpetra::EpetraNode >.
Definition at line 180 of file MueLu_Ifpack2Smoother_def.hpp.
|
virtual |
Implements MueLu::SmootherPrototype< double, int, int, Xpetra::EpetraNode >.
Definition at line 187 of file MueLu_Ifpack2Smoother_def.hpp.
|
virtual |
Return a simple one-line description of this object.
Reimplemented from MueLu::Describable.
Definition at line 195 of file MueLu_Ifpack2Smoother_def.hpp.
| void MueLu::Ifpack2Smoother< double, int, int, Xpetra::EpetraNode >::print | ( | Teuchos::FancyOStream & | out, |
| const VerbLevel | verbLevel = Default ) const |
Print the object with some verbosity level to an FancyOStream object.
Definition at line 200 of file MueLu_Ifpack2Smoother_def.hpp.
|
inline |
For diagnostic purposes.
Definition at line 205 of file MueLu_Ifpack2Smoother_decl.hpp.
|
virtual |
Get a rough estimate of cost per iteration.
Implements MueLu::SmootherBase< double, int, int, Xpetra::EpetraNode >.
Definition at line 208 of file MueLu_Ifpack2Smoother_def.hpp.
|
private |
Definition at line 211 of file MueLu_Ifpack2Smoother_def.hpp.
|
private |
Definition at line 213 of file MueLu_Ifpack2Smoother_def.hpp.
|
private |
Definition at line 214 of file MueLu_Ifpack2Smoother_def.hpp.
|
private |
Definition at line 215 of file MueLu_Ifpack2Smoother_def.hpp.
|
private |
Definition at line 216 of file MueLu_Ifpack2Smoother_def.hpp.
|
private |
|
private |
Definition at line 218 of file MueLu_Ifpack2Smoother_def.hpp.
|
private |
Definition at line 219 of file MueLu_Ifpack2Smoother_def.hpp.
|
private |
Definition at line 220 of file MueLu_Ifpack2Smoother_def.hpp.
|
private |
Definition at line 221 of file MueLu_Ifpack2Smoother_def.hpp.
|
friend |
Definition at line 259 of file MueLu_Ifpack2Smoother_decl.hpp.
|
friend |
Constructor.
The options passed into Ifpack2Smoother are those given in the Ifpack2 user's manual.
| type | smoother type |
| list | options for the particular smoother (e.g., fill factor or damping parameter) |
Here is how to select some of the most common smoothers.
type = point relaxation stand-alonerelaxation: type = Gauss-Seidelrelaxation: damping factortype = point relaxation stand-alonerelaxation: type = symmetric Gauss-Seidelrelaxation: damping factortype = Chebyshevchebyshev: ratio eigenvaluechebyshev: min eigenvaluechebyshev: max eigenvaluechebyshev: degreechebyshev: zero starting solution (defaults to true)type = ILUfact: level-of-fillSee also Ifpack2::Relaxation, Ifpack2::Chebyshev, or Ifpack2::ILUT.
Definition at line 141 of file MueLu_Ifpack2Smoother_decl.hpp.
|
private |
Definition at line 225 of file MueLu_Ifpack2Smoother_decl.hpp.
|
private |
ifpack2-specific key phrase that denote smoother type
Definition at line 228 of file MueLu_Ifpack2Smoother_decl.hpp.
|
private |
overlap when using the smoother in additive Schwarz mode
Definition at line 231 of file MueLu_Ifpack2Smoother_decl.hpp.
|
private |
pointer to Ifpack2 preconditioner object
Definition at line 234 of file MueLu_Ifpack2Smoother_decl.hpp.
|
private |
matrix, used in apply if solving residual equation
Definition at line 237 of file MueLu_Ifpack2Smoother_decl.hpp.