Newer
Older

Thomas Witkowski
committed
//
// Software License for AMDiS
//
// Copyright (c) 2010 Dresden University of Technology
// All rights reserved.
// Authors: Simon Vey, Thomas Witkowski et al.
//
// This file is part of AMDiS
//
// See also license.opensource.txt in the distribution.
#include "ITL_Solver.h"
#include "ITL_Preconditioner.h"
#include "MatrixVector.h"
#include "SystemVector.h"
#include "est/Estimator.h"
#include "LeafData.h"
#include "SurfaceRegion_ED.h"
#include "ElementRegion_ED.h"

Thomas Witkowski
committed
#include "DOFMatrix.h"
#include "est/RecoveryEstimator.h"
#include "est/ResidualEstimator.h"
#include "est/SimpleResidualEstimator.h"
#include "time/RosenbrockMethod.h"
#include "nonlin/NonLinSolver.h"
namespace AMDiS {
template<>
void CreatorMap<OEMSolver>::addDefaultCreators()
OEMSolverCreator *creator;
addCreator("cg", creator);
creator = new CGSSolver::Creator;
addCreator("cgs", creator);
addCreator("bicg", creator);
creator = new BiCGStabSolver::Creator;
addCreator("bicgstab", creator);
creator = new BiCGStab2Solver::Creator;
addCreator("bicgstab2", creator);
creator = new BiCGStabEllSolver::Creator;
addCreator("bicgstab_ell", creator);
creator = new QMRSolver::Creator;
addCreator("qmr", creator);
creator = new TFQMRSolver::Creator;
addCreator("tfqmr", creator);
creator = new GMResSolver::Creator;
addCreator("gmres", creator);
creator = new IDRsSolver::Creator;
addCreator("idr_s", creator);
creator = new MinResSolver::Creator;
addCreator("minres", creator);
#ifdef HAVE_UMFPACK
addCreator("umfpack", creator);
void CreatorMap<BasePreconditioner>::addDefaultCreators()
addCreator("diag", creator);
addCreator("ilu", creator);
addCreator("ic", creator);
template<>
void CreatorMap<Estimator>::addDefaultCreators()
{
EstimatorCreator *creator;
addCreator("residual", creator);
creator = new SimpleResidualEstimator::Creator;
addCreator("simple-residual", creator);
addCreator("recovery", creator);
}
template<>
void CreatorMap<ElementData>::addDefaultCreators()
{
CreatorInterface<ElementData> *creator;
addCreator("LeafDataEstimatable", creator);
creator = new LeafDataEstimatableVec::Creator;
addCreator("LeafDataEstimatableVec", creator);
addCreator("LeafDataCoarsenable", creator);
creator = new LeafDataCoarsenableVec::Creator;
addCreator("LeafDataCoarsenableVec", creator);
addCreator("LeafDataPeriodic", creator);
addCreator("SurfaceRegion_ED", creator);
addCreator("ElementRegion_ED", creator);
}
template<>
void CreatorMap<RosenbrockMethod>::addDefaultCreators()
{
addCreator("ros2", new Ros2::Creator);
addCreator("rowda3", new Rowda3::Creator);
addCreator("ros3p", new Ros3p::Creator);
addCreator("rodasp", new Rodasp::Creator);
}
template<>
void CreatorMap<NonLinSolver>::addDefaultCreators()
{
addCreator("newton", new Newton::Creator);
addCreator("newtonArmijo", new NewtonArmijo::Creator);