10#ifndef MUELU_FACTORYMANAGER_DEF_HPP
11#define MUELU_FACTORYMANAGER_DEF_HPP
13#include <Teuchos_ParameterList.hpp>
16#include "MueLu_AmalgamationFactory.hpp"
17#include "MueLu_CoalesceDropFactory.hpp"
18#include "MueLu_CoarseMapFactory.hpp"
19#include "MueLu_ConstraintFactory.hpp"
20#include "MueLu_AggregateQualityEstimateFactory.hpp"
21#include "MueLu_DirectSolver.hpp"
22#include "MueLu_InitialBlockNumberFactory.hpp"
23#include "MueLu_LineDetectionFactory.hpp"
24#include "MueLu_MultiVectorTransferFactory.hpp"
26#include "MueLu_NullspaceFactory.hpp"
27#include "MueLu_PatternFactory.hpp"
28#include "MueLu_RAPFactory.hpp"
29#include "MueLu_RepartitionHeuristicFactory.hpp"
30#include "MueLu_RepartitionFactory.hpp"
31#include "MueLu_SaPFactory.hpp"
32#include "MueLu_ScaledNullspaceFactory.hpp"
33#include "MueLu_SmootherFactory.hpp"
34#include "MueLu_TentativePFactory.hpp"
35#include "MueLu_TransPFactory.hpp"
36#include "MueLu_TrilinosSmoother.hpp"
37#include "MueLu_UncoupledAggregationFactory.hpp"
38#include "MueLu_StructuredAggregationFactory.hpp"
39#include "MueLu_ZoltanInterface.hpp"
40#include "MueLu_InterfaceMappingTransferFactory.hpp"
41#include "MueLu_InterfaceAggregationFactory.hpp"
42#include "MueLu_InverseApproximationFactory.hpp"
44#include "MueLu_CoalesceDropFactory_kokkos.hpp"
45#include "MueLu_TentativePFactory_kokkos.hpp"
51#define MUELU_KOKKOS_FACTORY(varName, oldFactory, newFactory) \
52 (!useKokkos_) ? SetAndReturnDefaultFactory(varName, rcp(new oldFactory())) : SetAndReturnDefaultFactory(varName, rcp(new newFactory()));
54template <
class Scalar,
class LocalOrdinal,
class GlobalOrdinal,
class Node>
56 SetIgnoreUserData(
false);
57 useKokkos_ = !Node::is_serial;
60template <
class Scalar,
class LocalOrdinal,
class GlobalOrdinal,
class Node>
62 factoryTable_ = factoryTable;
63 SetIgnoreUserData(
false);
64 useKokkos_ = !Node::is_serial;
67template <
class Scalar,
class LocalOrdinal,
class GlobalOrdinal,
class Node>
70template <
class Scalar,
class LocalOrdinal,
class GlobalOrdinal,
class Node>
72 factoryTable_[varName] = factory;
75template <
class Scalar,
class LocalOrdinal,
class GlobalOrdinal,
class Node>
77 if (factoryTable_.count(varName)) {
79 return factoryTable_.find(varName)->second;
83 return GetDefaultFactory(varName);
86template <
class Scalar,
class LocalOrdinal,
class GlobalOrdinal,
class Node>
88 return Teuchos::rcp_const_cast<FactoryBase>(GetFactory(varName));
91template <
class Scalar,
class LocalOrdinal,
class GlobalOrdinal,
class Node>
93 if (factoryTable_.count(varName))
return true;
97template <
class Scalar,
class LocalOrdinal,
class GlobalOrdinal,
class Node>
99 if (defaultFactoryTable_.count(varName)) {
101 return defaultFactoryTable_.find(varName)->second;
105 if (varName ==
"A")
return SetAndReturnDefaultFactory(varName, rcp(
new RAPFactory()));
107 if (varName ==
"RAP Pattern")
return GetFactory(
"A");
108 if (varName ==
"AP Pattern")
return GetFactory(
"A");
110 if (varName ==
"P") {
113 factory->SetFactory(
"P", GetFactory(
"Ptent"));
114 return SetAndReturnDefaultFactory(varName, factory);
116 if (varName ==
"Nullspace") {
119 factory->SetFactory(
"Nullspace", GetFactory(
"Ptent"));
120 return SetAndReturnDefaultFactory(varName, factory);
122 if (varName ==
"Scaled Nullspace")
return SetAndReturnDefaultFactory(varName, rcp(
new ScaledNullspaceFactory()));
123 if (varName ==
"Material") {
125 Teuchos::ParameterList pl;
126 pl.set(
"Vector name",
"Material");
127 pl.set(
"Transfer name",
"Aggregates");
128 pl.set(
"Normalize",
true);
129 fact->SetParameterList(pl);
132 if (varName ==
"Coordinates")
return GetFactory(
"Ptent");
133 if (varName ==
"Node Comm")
return GetFactory(
"Ptent");
135 if (varName ==
"R")
return SetAndReturnDefaultFactory(varName, rcp(
new TransPFactory()));
136 if (varName ==
"RfromPfactory")
return GetFactory(
"P");
137#if defined(HAVE_MUELU_ZOLTAN) && defined(HAVE_MPI)
138 if (varName ==
"Partition")
return SetAndReturnDefaultFactory(varName, rcp(
new ZoltanInterface()));
141 if (varName ==
"Importer") {
148 if (varName ==
"number of partitions") {
155 if (varName ==
"repartition: heuristic target rows per process")
return GetFactory(
"number of partitions");
158 if (varName ==
"UnAmalgamationInfo")
return SetAndReturnDefaultFactory(varName, rcp(
new AmalgamationFactory()));
161 if (varName ==
"CoarseMap")
return SetAndReturnDefaultFactory(varName, rcp(
new CoarseMapFactory()));
162 if (varName ==
"DofsPerNode")
return GetFactory(
"Graph");
163 if (varName ==
"Filtering")
return GetFactory(
"Graph");
165 if (varName ==
"LineDetection_VertLineIds")
return SetAndReturnDefaultFactory(varName, rcp(
new LineDetectionFactory()));
166 if (varName ==
"LineDetection_Layers")
return GetFactory(
"LineDetection_VertLineIds");
167 if (varName ==
"CoarseNumZLayers")
return GetFactory(
"LineDetection_VertLineIds");
173 if (varName ==
"K")
return GetFactory(
"A");
174 if (varName ==
"M")
return GetFactory(
"A");
175 if (varName ==
"Mdiag")
return GetFactory(
"A");
176 if (varName ==
"cfl-based shift array")
return GetFactory(
"A");
179 if (varName ==
"PreSmoother")
return GetFactory(
"Smoother");
180 if (varName ==
"PostSmoother")
return GetFactory(
"Smoother");
182 if (varName ==
"Ppattern") {
184 PpFact->SetFactory(
"P", GetFactory(
"Ptent"));
185 return SetAndReturnDefaultFactory(varName, PpFact);
187 if (varName ==
"Constraint")
return SetAndReturnDefaultFactory(varName, rcp(
new ConstraintFactory()));
189 if (varName ==
"Smoother") {
190 Teuchos::ParameterList smootherParamList;
191 smootherParamList.set(
"relaxation: type",
"Symmetric Gauss-Seidel");
192 smootherParamList.set(
"relaxation: sweeps", Teuchos::OrdinalTraits<LO>::one());
193 smootherParamList.set(
"relaxation: damping factor", Teuchos::ScalarTraits<Scalar>::one());
196 if (varName ==
"CoarseSolver")
return SetAndReturnDefaultFactory(varName, rcp(
new SmootherFactory(rcp(
new DirectSolver()), Teuchos::null)));
199 if (varName ==
"CoarseDualNodeID2PrimalNodeID")
return SetAndReturnDefaultFactory(varName, rcp(
new InterfaceAggregationFactory()));
200#ifdef HAVE_MUELU_INTREPID2
202 if (varName ==
"pcoarsen: element to node map")
return GetFactory(
"P");
210 TEUCHOS_TEST_FOR_EXCEPTION(
true,
MueLu::Exceptions::RuntimeError,
"MueLu::FactoryManager::GetDefaultFactory(): No default factory available for building '" + varName +
"'.");
214template <
class Scalar,
class LocalOrdinal,
class GlobalOrdinal,
class Node>
216 TEUCHOS_TEST_FOR_EXCEPTION(factory.is_null(),
Exceptions::RuntimeError,
"The default factory for building '" << varName <<
"' is null");
218 GetOStream(
Runtime1) <<
"Using default factory (" << factory->ShortClassName() <<
"[" << factory->GetID() <<
"]) for building '" << varName <<
"'." << std::endl;
220 defaultFactoryTable_[varName] = factory;
222 return defaultFactoryTable_[varName];
225template <
class Scalar,
class LocalOrdinal,
class GlobalOrdinal,
class Node>
227 std::map<std::string, RCP<const FactoryBase> >::const_iterator it;
228 Teuchos::FancyOStream& fancy = GetOStream(
Debug);
231 fancy <<
"Users factory table (factoryTable_):" << std::endl;
232 for (it = factoryTable_.begin(); it != factoryTable_.end(); it++) {
233 fancy <<
" " << it->first <<
" -> ";
235 fancy <<
"NoFactory";
236 else if (!it->second.get())
239 fancy << it->second.get()->ShortClassName() <<
"[" << it->second.get()->GetID() <<
"]";
240#ifdef HAVE_MUELU_DEBUG
241 fancy <<
"(" << Teuchos::toString(it->second.get()) <<
")";
247 fancy <<
"Default factory table (defaultFactoryTable_):" << std::endl;
248 for (it = defaultFactoryTable_.begin(); it != defaultFactoryTable_.end(); it++) {
249 fancy <<
" " << it->first <<
" -> ";
251 fancy <<
"NoFactory";
252 else if (!it->second.get())
255 fancy << it->second.get()->ShortClassName() <<
"[" << it->second.get()->GetID() <<
"]";
256#ifdef HAVE_MUELU_DEBUG
257 fancy <<
"(" << Teuchos::toString(it->second.get()) <<
")";
264#ifdef HAVE_MUELU_DEBUG
265template <
class Scalar,
class LocalOrdinal,
class GlobalOrdinal,
class Node>
267 std::map<std::string, RCP<const FactoryBase> >::const_iterator it;
269 for (it = factoryTable_.begin(); it != factoryTable_.end(); it++)
270 if (!it->second.is_null())
271 it->second->ResetDebugData();
273 for (it = defaultFactoryTable_.begin(); it != defaultFactoryTable_.end(); it++)
274 if (!it->second.is_null())
275 it->second->ResetDebugData();
279#undef MUELU_KOKKOS_FACTORY
#define MUELU_KOKKOS_FACTORY(varName, oldFactory, newFactory)
An factory which assigns each aggregate a quality estimate. Originally developed by Napov and Notay i...
AmalgamationFactory for subblocks of strided map based amalgamation data.
Factory for creating a graph based on a given matrix.
Factory for creating a graph based on a given matrix.
Factory for generating coarse level map. Used by TentativePFactory.
Factory for building the constraint operator.
Class that encapsulates direct solvers. Autoselection of AmesosSmoother or Amesos2Smoother according ...
Exception throws to report errors in the internal logical of the program.
This class specifies the default factory that should generate some data on a Level if the data does n...
const RCP< const FactoryBase > GetDefaultFactory(const std::string &varName) const
const RCP< const FactoryBase > SetAndReturnDefaultFactory(const std::string &varName, const RCP< const FactoryBase > &factory) const
void SetFactory(const std::string &varName, const RCP< const FactoryBase > &factory)
Set Factory.
bool hasFactory(const std::string &varName) const
Check.
const RCP< const FactoryBase > GetFactory(const std::string &varName) const
Get factory associated with a particular data name.
FactoryManager()
Constructor.
const RCP< FactoryBase > GetFactoryNonConst(const std::string &varName)
Get factory associated with a particular data name (NONCONST version)
virtual ~FactoryManager()
Destructor.
Class for generating an initial LocalOrdinal-type BlockNumber vector, based on an input paraemter for...
Factory for building aggregates for Lagrange multipliers in surface-coupled problems.
Transfer mapping data for interface aggregation to the coarse level.
Factory for building the approximate inverse of a matrix.
Factory for building line detection information.
Class for restricting a MultiVector from a finer to a coarser level.
static const RCP< const NoFactory > getRCP()
Static Get() functions.
static const NoFactory * get()
Factory for generating nullspace.
Factory for building nonzero patterns for energy minimization.
Factory for building coarse matrices.
Factory for building permutation matrix that can be be used to shuffle data (matrices,...
Factory for determing the number of partitions for rebalancing.
Factory for building Smoothed Aggregation prolongators.
Factory for generating a very special nullspace.
Generic Smoother Factory for generating the smoothers of the MG hierarchy.
Factory for building aggregates on structured grids.
Factory for building tentative prolongator.
Factory for building restriction operators.
Class that encapsulates external library smoothers.
Factory for building uncoupled aggregates.
Interface to Zoltan library.
Namespace for MueLu classes and methods.
@ Debug
Print additional debugging information.
@ Runtime1
Description of what is happening (more verbose)