46 #ifndef MUELU_TWOLEVELFACTORY_HPP
47 #define MUELU_TWOLEVELFACTORY_HPP
54 #include "MueLu_Utilities.hpp"
96 std::ostringstream errStr;
97 errStr <<
"LevelID = " << requestedLevel.
GetLevelID();
116 #ifdef HAVE_MUELU_DEBUG
118 TEUCHOS_TEST_FOR_EXCEPTION((multipleCallCheck_ == ENABLED) && (multipleCallCheckGlobal_ == ENABLED) && (lastLevelID_ == levelID),
120 this->
ShortClassName() <<
"::Build() called twice for the same level (levelID=" << levelID
121 <<
"). This is likely due to a configuration error, or calling hierarchy setup multiple times "
122 <<
"without resetting debug info through FactoryManager::ResetDebugData().");
123 if (multipleCallCheck_ == FIRSTCALL)
124 multipleCallCheck_ = ENABLED;
126 lastLevelID_ = levelID;
131 if (comm.is_null()) {
137 comm = prevLevel->GetComm();
146 if (this->timerSync_ && !comm.is_null()) {
153 if (this->timerSync_ && !comm.is_null()) {
171 #define MUELU_TWOLEVELFACTORY_SHORT
172 #endif //ifndef MUELU_TWOLEVELFACTORY_HPP
virtual const Teuchos::ParameterList & GetParameterList() const
RCP< Level > & GetPreviousLevel()
Previous level.
std::string toString(const T &what)
Little helper function to convert non-string types to strings.
#define TEUCHOS_TEST_FOR_EXCEPTION(throw_exception_test, Exception, msg)
Base class for factories that use two levels (fineLevel and coarseLevel).
virtual void CallBuild(Level &requestedLevel) const
Integrates Teuchos::TimeMonitor with MueLu verbosity system.
virtual std::string ShortClassName() const
Return the class name of the object, without template parameters and without namespace.
int SetProcRankVerbose(int procRank) const
Set proc rank used for printing.
Class that holds all level-specific information.
virtual ~TwoLevelFactoryBase()
Destructor.
virtual void Build(Level &fineLevel, Level &coarseLevel) const =0
Build an object with this factory.
Teuchos::FancyOStream & GetOStream(MsgType type, int thisProcRankOnly=0) const
Get an output stream for outputting the input message type.
TwoLevelFactoryBase()
Constructor.
virtual void CallDeclareInput(Level &requestedLevel) const
int GetLevelID() const
Return level number.
Exception throws to report errors in the internal logical of the program.
RCP< const Teuchos::Comm< int > > GetComm() const
virtual void DeclareInput(Level &fineLevel, Level &coarseLevel) const =0
Input.
Exception throws to report data dependency problems between factories.