47 #ifndef MUELU_MATLABSMOOTHER_DEF_HPP 
   48 #define MUELU_MATLABSMOOTHER_DEF_HPP 
   51 #if defined(HAVE_MUELU_TPETRA) && defined(HAVE_MUELU_MATLAB) 
   57   template <
class Scalar,
class LocalOrdinal, 
class GlobalOrdinal, 
class Node>
 
   60     SetParameterList(paramList);
 
   63   template <
class Scalar,
class LocalOrdinal, 
class GlobalOrdinal, 
class Node>
 
   68     setupFunction_ = pL.
get(
"Setup Function",
"");
 
   69     solveFunction_ = pL.
get(
"Solve Function",
"");
 
   70     solveDataSize_ = pL.
get(
"Number of Solver Args", 0);
 
   73   template <
class Scalar,
class LocalOrdinal, 
class GlobalOrdinal, 
class Node>
 
   77     this->Input(currentLevel, 
"A");
 
   79     needsSetup_ = pL.
get<
string>(
"Needs");
 
   81     for(
size_t i = 0; i < needsList.size(); i++)
 
   84         this->Input(currentLevel, needsList[i]);
 
   88   template <
class Scalar,
class LocalOrdinal, 
class GlobalOrdinal, 
class Node>
 
   93     if (this->IsSetup() == 
true)
 
   94       this->GetOStream(
Warnings0) << 
"MueLu::MatlabSmoother::Setup(): Setup() has already been called";
 
   95     vector<RCP<MuemexArg>> InputArgs = processNeeds<Scalar, LocalOrdinal, GlobalOrdinal, Node>(
this, needsSetup_, currentLevel);
 
   96     A_ = Factory::Get<RCP<Matrix>>(currentLevel, 
"A");
 
   99     InputArgs.insert(InputArgs.begin(), AmatArg);
 
  101     if(!setupFunction_.length())
 
  102       throw runtime_error(
"Invalid matlab function name");
 
  103     solveData_= 
callMatlab(setupFunction_, solveDataSize_, InputArgs);
 
  104     this->GetOStream(
Statistics1) << description() << endl;
 
  108   template <
class Scalar, 
class LocalOrdinal, 
class GlobalOrdinal, 
class Node>
 
  112     using namespace Teuchos;
 
  115     vector<RCP<MuemexArg>> InputArgs;
 
  119     MultiVector* BPtrNonConst = (MultiVector*) &B;
 
  123     InputArgs.push_back(XData);
 
  124     InputArgs.push_back(BData);
 
  125     for(
size_t i = 0; i < solveData_.size(); i++)
 
  126       InputArgs.push_back(solveData_[i]);
 
  127     if(!solveFunction_.length()) 
throw std::runtime_error(
"Invalid matlab function name");
 
  128     vector<Teuchos::RCP<MuemexArg>> mexOutput = 
callMatlab(solveFunction_, 1, InputArgs);
 
  130     X = *(mydata->getData());
 
  133   template <
class Scalar,
class LocalOrdinal, 
class GlobalOrdinal, 
class Node>
 
  137     smoother->SetParameterList(this->GetParameterList());
 
  141   template <
class Scalar,
class LocalOrdinal, 
class GlobalOrdinal, 
class Node>
 
  143     std::ostringstream out;
 
  145       out << 
"Matlab Smoother("<<setupFunction_<<
"/"<<solveFunction_<<
")";
 
  152   template <
class Scalar,
class LocalOrdinal, 
class GlobalOrdinal, 
class Node>
 
  157       out << 
"Matlab Smoother("<<setupFunction_<<
"/"<<solveFunction_<<
")";
 
  160       out0 << 
"Parameter list: " << std::endl;
 
  162       out << this->GetParameterList();
 
  165     if (verbLevel & 
Debug) {
 
  193 #endif // HAVE_MUELU_TPETRA && HAVE_MUELU_MATLAB 
  194 #endif // MUELU_MATLABSMOOTHER_DEF_HPP 
Important warning messages (one line) 
void SetParameterList(const Teuchos::ParameterList ¶mList)
Set parameters from a parameter list and return with default values. 
void DeclareInput(Level ¤tLevel) const 
Input. 
std::vector< std::string > tokenizeList(const std::string ¶ms)
void Apply(MultiVector &X, const MultiVector &B, bool InitialGuessIsZero=false) const 
Apply the preconditioner. 
RCP< SmootherPrototype > Copy() const 
T & get(const std::string &name, T def_value)
Timer to be used in factories. Similar to Monitor but with additional timers. 
#define TEUCHOS_TEST_FOR_EXCEPTION(throw_exception_test, Exception, msg)
void Setup(Level ¤tLevel)
Set up the smoother. 
Print additional debugging information. 
bool IsParamMuemexVariable(const std::string &name)
virtual void SetParameterList(const Teuchos::ParameterList ¶mList)
Set parameters from a parameter list and return with default values. 
TEUCHOS_DEPRECATED RCP< T > rcp(T *p, Dealloc_T dealloc, bool owns_mem)
Class that holds all level-specific information. 
void print(Teuchos::FancyOStream &out, const VerbLevel verbLevel=Default) const 
Print the object with some verbosity level to an FancyOStream object. 
bool IsSetup() const 
Get the state of a smoother prototype. 
#define MUELU_DESCRIBE
Helper macro for implementing Describable::describe() for BaseClass objects. 
friend class MatlabSmoother
Constructor. 
Class that encapsulates Matlab smoothers. 
std::string description() const 
Return a simple one-line description of this object. 
Print class parameters (more parameters, more verbose) 
Exception throws to report errors in the internal logical of the program. 
virtual std::string description() const 
Return a simple one-line description of this object. 
std::string toString(const T &t)
std::vector< RCP< MuemexArg > > callMatlab(std::string function, int numOutputs, std::vector< RCP< MuemexArg >> args)