#include "ml_config.h"
#include "ml_common.h"
#ifdef HAVE_ML_MLAPI
#include "MLAPI_Space.h"
#include "MLAPI_Operator.h"
#include "MLAPI_MultiVector.h"
#include "MLAPI_Gallery.h"
#include "MLAPI_Expressions.h"
#include "MLAPI_MultiLevelAdaptiveSA.h"
#include "MLAPI_DistributedMatrix.h"
#include "MLAPI_Krylov.h"
using namespace Teuchos;
using namespace MLAPI;
int main(int argc, char *argv[])
{
#ifdef HAVE_MPI
MPI_Init(&argc,&argv);
#endif
try {
Init();
int NX = 1000;
Space FineSpace(2*NX);
DistributedMatrix MatA(FineSpace, FineSpace);
if (GetMyPID() == 0) {
for (int i = 0 ; i < NX ; ++i) {
MatA.SetElement(2*i, 2*i, 2.0);
MatA.SetElement(2*i+1, 2*i+1, 2.0);
if (i)
{
MatA.SetElement(2*i, 2*(i - 1), - 1.0);
MatA.SetElement(2*i+1, 2*(i - 1)+1, - 1.0);
}
if (i != NX - 1) {
MatA.SetElement(2*i, 2*(i + 1), - 1.0);
MatA.SetElement(2*i+1, 2*(i + 1)+1, - 1.0);
}
}
}
MatA.FillComplete();
Operator A(FineSpace, FineSpace, &MatA, false);
int NumPDEEqns = 2;
int MaxLevels = 10;
Teuchos::ParameterList List;
List.set("additional candidates", 2);
List.set("use default null space", true);
List.set("krylov: type", "cg");
MultiLevelAdaptiveSA Prec(A, List, NumPDEEqns, MaxLevels);
bool UseDefaultNullSpace = true;
int AdditionalCandidates = 1;
Prec.AdaptCompute(UseDefaultNullSpace, AdditionalCandidates);
MultiVector LHS(A.GetDomainSpace());
MultiVector RHS(A.GetRangeSpace());
LHS.Random();
RHS = 0.0;
Krylov(A, LHS, RHS, Prec, List);
Finalize();
}
catch (const int e) {
cerr << "Caught integer exception, code = " << e << endl;
}
catch (...) {
cerr << "Caught exception..." << endl;
}
#ifdef HAVE_MPI
MPI_Finalize() ;
#endif
return(0);
}
#else
#include "ml_include.h"
int main(int argc, char *argv[])
{
#ifdef HAVE_MPI
MPI_Init(&argc,&argv);
#endif
puts("The ML API requires the following configuration options:");
puts("\t--enable-epetra");
puts("\t--enable-teuchos");
puts("\t--enable-ifpack");
puts("\t--enable-amesos");
puts("Please check your configure line.");
#ifdef HAVE_MPI
MPI_Finalize();
#endif
return(0);
}
#endif // #if defined(HAVE_ML_MLAPI)