128 std::string factoryName;
129 Teuchos::ParameterList paramList;
130 if (!param.isList()) {
131 factoryName = Teuchos::getValue<std::string>(param);
133 paramList = Teuchos::getValue<Teuchos::ParameterList>(param);
134 factoryName = paramList.get<std::string>(
"factory");
138 if (factoryName ==
"AggregateQualityEstimateFactory")
return Build2<AggregateQualityEstimateFactory>(paramList, factoryMapIn, factoryManagersIn);
139 if (factoryName ==
"AggregationExportFactory")
return Build2<AggregationExportFactory>(paramList, factoryMapIn, factoryManagersIn);
140 if (factoryName ==
"AmalgamationFactory")
return Build2<AmalgamationFactory>(paramList, factoryMapIn, factoryManagersIn);
141 if (factoryName ==
"BlockedCoarseMapFactory")
return Build2<BlockedCoarseMapFactory>(paramList, factoryMapIn, factoryManagersIn);
142 if (factoryName ==
"BlockedRAPFactory")
return BuildRAPFactory<BlockedRAPFactory>(paramList, factoryMapIn, factoryManagersIn);
143 if (factoryName ==
"BrickAggregationFactory")
return Build2<BrickAggregationFactory>(paramList, factoryMapIn, factoryManagersIn);
144 if (factoryName ==
"ClassicalMapFactory")
return Build2<ClassicalMapFactory>(paramList, factoryMapIn, factoryManagersIn);
145 if (factoryName ==
"ClassicalPFactory")
return Build2<ClassicalPFactory>(paramList, factoryMapIn, factoryManagersIn);
146 if (factoryName ==
"CloneRepartitionInterface")
return Build2<CloneRepartitionInterface>(paramList, factoryMapIn, factoryManagersIn);
147 if (factoryName ==
"CoarseMapFactory")
return Build2<CoarseMapFactory>(paramList, factoryMapIn, factoryManagersIn);
148 if (factoryName ==
"CoarseningVisualizationFactory")
return Build2<CoarseningVisualizationFactory>(paramList, factoryMapIn, factoryManagersIn);
149 if (factoryName ==
"CoalesceDropFactory")
return Build2<CoalesceDropFactory>(paramList, factoryMapIn, factoryManagersIn);
150 if (factoryName ==
"SmooVecCoalesceDropFactory")
return Build2<SmooVecCoalesceDropFactory>(paramList, factoryMapIn, factoryManagersIn);
151 if (factoryName ==
"ConstraintFactory")
return Build2<ConstraintFactory>(paramList, factoryMapIn, factoryManagersIn);
152 if (factoryName ==
"CoordinatesTransferFactory")
return Build2<CoordinatesTransferFactory>(paramList, factoryMapIn, factoryManagersIn);
153 if (factoryName ==
"DirectSolver")
return BuildDirectSolver(paramList, factoryMapIn, factoryManagersIn);
154 if (factoryName ==
"DropNegativeEntriesFactory")
return Build2<DropNegativeEntriesFactory>(paramList, factoryMapIn, factoryManagersIn);
155 if (factoryName ==
"EminPFactory")
return Build2<EminPFactory>(paramList, factoryMapIn, factoryManagersIn);
156 if (factoryName ==
"FilteredAFactory")
return Build2<FilteredAFactory>(paramList, factoryMapIn, factoryManagersIn);
157 if (factoryName ==
"FineLevelInputDataFactory")
return Build2<FineLevelInputDataFactory>(paramList, factoryMapIn, factoryManagersIn);
158 if (factoryName ==
"GeneralGeometricPFactory")
return Build2<GeneralGeometricPFactory>(paramList, factoryMapIn, factoryManagersIn);
159 if (factoryName ==
"ReplicatePFactory")
return Build2<ReplicatePFactory>(paramList, factoryMapIn, factoryManagersIn);
160 if (factoryName ==
"CombinePFactory")
return Build2<CombinePFactory>(paramList, factoryMapIn, factoryManagersIn);
161 if (factoryName ==
"GenericRFactory")
return Build2<GenericRFactory>(paramList, factoryMapIn, factoryManagersIn);
162 if (factoryName ==
"GeometricInterpolationPFactory")
return Build2<GeometricInterpolationPFactory>(paramList, factoryMapIn, factoryManagersIn);
163 if (factoryName ==
"HybridAggregationFactory")
return Build2<HybridAggregationFactory>(paramList, factoryMapIn, factoryManagersIn);
164 if (factoryName ==
"InterfaceAggregationFactory")
return Build2<InterfaceAggregationFactory>(paramList, factoryMapIn, factoryManagersIn);
165 if (factoryName ==
"InterfaceMappingTransferFactory")
return Build2<InterfaceMappingTransferFactory>(paramList, factoryMapIn, factoryManagersIn);
166 if (factoryName ==
"InverseApproximationFactory")
return Build2<InverseApproximationFactory>(paramList, factoryMapIn, factoryManagersIn);
167 if (factoryName ==
"InitialBlockNumberFactory")
return Build2<InitialBlockNumberFactory>(paramList, factoryMapIn, factoryManagersIn);
168 if (factoryName ==
"LineDetectionFactory")
return Build2<LineDetectionFactory>(paramList, factoryMapIn, factoryManagersIn);
171 if (factoryName ==
"MapTransferFactory")
return Build2<MapTransferFactory>(paramList, factoryMapIn, factoryManagersIn);
172 if (factoryName ==
"MatrixAnalysisFactory")
return Build2<MatrixAnalysisFactory>(paramList, factoryMapIn, factoryManagersIn);
173 if (factoryName ==
"MultiVectorTransferFactory")
return Build2<MultiVectorTransferFactory>(paramList, factoryMapIn, factoryManagersIn);
175 if (factoryName ==
"NoSmoother")
return rcp(
new SmootherFactory(Teuchos::null));
176 if (factoryName ==
"NotayAggregationFactory")
return Build2<NotayAggregationFactory>(paramList, factoryMapIn, factoryManagersIn);
177 if (factoryName ==
"NullspaceFactory")
return Build2<NullspaceFactory>(paramList, factoryMapIn, factoryManagersIn);
178 if (factoryName ==
"NullspacePresmoothFactory")
return Build2<NullspacePresmoothFactory>(paramList, factoryMapIn, factoryManagersIn);
179 if (factoryName ==
"PatternFactory")
return Build2<PatternFactory>(paramList, factoryMapIn, factoryManagersIn);
180 if (factoryName ==
"PgPFactory")
return Build2<PgPFactory>(paramList, factoryMapIn, factoryManagersIn);
181 if (factoryName ==
"SaPFactory")
return Build2<SaPFactory>(paramList, factoryMapIn, factoryManagersIn);
182 if (factoryName ==
"RAPFactory")
return BuildRAPFactory<RAPFactory>(paramList, factoryMapIn, factoryManagersIn);
183 if (factoryName ==
"RAPShiftFactory")
return BuildRAPFactory<RAPShiftFactory>(paramList, factoryMapIn, factoryManagersIn);
184 if (factoryName ==
"RebalanceAcFactory")
return Build2<RebalanceAcFactory>(paramList, factoryMapIn, factoryManagersIn);
185 if (factoryName ==
"RebalanceTransferFactory")
return Build2<RebalanceTransferFactory>(paramList, factoryMapIn, factoryManagersIn);
186 if (factoryName ==
"RegionRFactory")
return Build2<RegionRFactory>(paramList, factoryMapIn, factoryManagersIn);
187 if (factoryName ==
"RegionRFactory_kokkos")
return Build2<RegionRFactory_kokkos>(paramList, factoryMapIn, factoryManagersIn);
188 if (factoryName ==
"ReorderBlockAFactory")
return Build2<ReorderBlockAFactory>(paramList, factoryMapIn, factoryManagersIn);
189 if (factoryName ==
"RepartitionInterface")
return Build2<RepartitionInterface>(paramList, factoryMapIn, factoryManagersIn);
190 if (factoryName ==
"ScaledNullspaceFactory")
return Build2<ScaledNullspaceFactory>(paramList, factoryMapIn, factoryManagersIn);
191 if (factoryName ==
"SegregatedAFactory")
return Build2<SegregatedAFactory>(paramList, factoryMapIn, factoryManagersIn);
192 if (factoryName ==
"SemiCoarsenPFactory")
return Build2<SemiCoarsenPFactory>(paramList, factoryMapIn, factoryManagersIn);
193 if (factoryName ==
"StructuredAggregationFactory")
return Build2<StructuredAggregationFactory>(paramList, factoryMapIn, factoryManagersIn);
194 if (factoryName ==
"StructuredLineDetectionFactory")
return Build2<StructuredLineDetectionFactory>(paramList, factoryMapIn, factoryManagersIn);
195 if (factoryName ==
"SubBlockAFactory")
return Build2<SubBlockAFactory>(paramList, factoryMapIn, factoryManagersIn);
196 if (factoryName ==
"TentativePFactory")
return Build2<TentativePFactory>(paramList, factoryMapIn, factoryManagersIn);
197 if (factoryName ==
"ToggleCoordinatesTransferFactory")
return BuildToggleCoordinatesTransferFactory(paramList, factoryMapIn, factoryManagersIn);
198 if (factoryName ==
"TogglePFactory")
return BuildTogglePFactory<TogglePFactory>(paramList, factoryMapIn, factoryManagersIn);
199 if (factoryName ==
"TransPFactory")
return Build2<TransPFactory>(paramList, factoryMapIn, factoryManagersIn);
200 if (factoryName ==
"RfromP_Or_TransP")
return Build2<RfromP_Or_TransP>(paramList, factoryMapIn, factoryManagersIn);
201 if (factoryName ==
"TrilinosSmoother")
return BuildTrilinosSmoother(paramList, factoryMapIn, factoryManagersIn);
202 if (factoryName ==
"UncoupledAggregationFactory")
return Build2<UncoupledAggregationFactory>(paramList, factoryMapIn, factoryManagersIn);
203 if (factoryName ==
"UnsmooshFactory")
return Build2<UnsmooshFactory>(paramList, factoryMapIn, factoryManagersIn);
204 if (factoryName ==
"UserAggregationFactory")
return Build2<UserAggregationFactory>(paramList, factoryMapIn, factoryManagersIn);
205 if (factoryName ==
"UserPFactory")
return Build2<UserPFactory>(paramList, factoryMapIn, factoryManagersIn);
206 if (factoryName ==
"VariableDofLaplacianFactory")
return Build2<VariableDofLaplacianFactory>(paramList, factoryMapIn, factoryManagersIn);
207 if (factoryName ==
"ZeroSubBlockAFactory")
return Build2<ZeroSubBlockAFactory>(paramList, factoryMapIn, factoryManagersIn);
208 if (factoryName ==
"CoalesceDropFactory_kokkos")
return Build2<CoalesceDropFactory_kokkos>(paramList, factoryMapIn, factoryManagersIn);
209 if (factoryName ==
"GeometricInterpolationPFactory_kokkos")
return Build2<GeometricInterpolationPFactory_kokkos>(paramList, factoryMapIn, factoryManagersIn);
210 if (factoryName ==
"SemiCoarsenPFactory_kokkos")
return Build2<SemiCoarsenPFactory_kokkos>(paramList, factoryMapIn, factoryManagersIn);
211 if (factoryName ==
"StructuredAggregationFactory_kokkos")
return Build2<StructuredAggregationFactory_kokkos>(paramList, factoryMapIn, factoryManagersIn);
212 if (factoryName ==
"TentativePFactory_kokkos")
return Build2<TentativePFactory_kokkos>(paramList, factoryMapIn, factoryManagersIn);
213 if (factoryName ==
"MatrixFreeTentativePFactory")
return Build2<MatrixFreeTentativePFactory>(paramList, factoryMapIn, factoryManagersIn);
216 if (factoryName ==
"CoarseMapFactory_kokkos")
return Build2<CoarseMapFactory>(paramList, factoryMapIn, factoryManagersIn);
217 if (factoryName ==
"CoordinatesTransferFactory_kokkos")
return Build2<CoordinatesTransferFactory>(paramList, factoryMapIn, factoryManagersIn);
219 if (factoryName ==
"ZoltanInterface") {
220#if defined(HAVE_MUELU_ZOLTAN) && defined(HAVE_MPI)
221 return Build2<ZoltanInterface>(paramList, factoryMapIn, factoryManagersIn);
223 TEUCHOS_TEST_FOR_EXCEPTION(
true,
Exceptions::RuntimeError,
"MueLu::FactoryFactory:BuildFactory(): Cannot create a ZoltanInterface object: Zoltan is disabled: HAVE_MUELU_ZOLTAN && HAVE_MPI == false.");
226 if (factoryName ==
"Zoltan2Interface") {
227#if defined(HAVE_MUELU_ZOLTAN2) && defined(HAVE_MPI)
228 return Build2<Zoltan2Interface>(paramList, factoryMapIn, factoryManagersIn);
230 TEUCHOS_TEST_FOR_EXCEPTION(
true,
Exceptions::RuntimeError,
"MueLu::FactoryFactory:BuildFactory(): Cannot create a Zoltan2Interface object: Zoltan2 is disabled: HAVE_MUELU_ZOLTAN2 && HAVE_MPI == false.");
233 if (factoryName ==
"IsorropiaInterface") {
234 TEUCHOS_TEST_FOR_EXCEPTION(
true,
Exceptions::RuntimeError,
"MueLu::FactoryFactory:BuildFactory(): Cannot create a IsorropiaInterface object: Isorropia is disabled: HAVE_MUELU_ISORROPIA && HAVE_MPI == false.");
237 if (factoryName ==
"NodePartitionInterface") {
239 return Build2<NodePartitionInterface>(paramList, factoryMapIn, factoryManagersIn);
241 TEUCHOS_TEST_FOR_EXCEPTION(
true,
Exceptions::RuntimeError,
"MueLu::FactoryFactory:BuildFactory(): Cannot create a NodePartitionInterface object: HAVE_MPI == false.");
245 if (factoryName ==
"RepartitionFactory") {
247 return Build2<RepartitionFactory>(paramList, factoryMapIn, factoryManagersIn);
249 TEUCHOS_TEST_FOR_EXCEPTION(
true,
Exceptions::RuntimeError,
"MueLu::FactoryFactory:BuildFactory(): Cannot create a RepartitionFactory object: HAVE_MPI == false.");
252 if (factoryName ==
"RepartitionHeuristicFactory") {
254 return Build2<RepartitionHeuristicFactory>(paramList, factoryMapIn, factoryManagersIn);
256 TEUCHOS_TEST_FOR_EXCEPTION(
true,
Exceptions::RuntimeError,
"MueLu::FactoryFactory:BuildFactory(): Cannot create a RepartitionHeuristicFactory object: HAVE_MPI == false.");
260 if (factoryName ==
"BlockedCoordinatesTransferFactory")
return BuildBlockedCoordFactory<BlockedCoordinatesTransferFactory>(paramList, factoryMapIn, factoryManagersIn);
261 if (factoryName ==
"BlockedDirectSolver")
return BuildBlockedDirectSolver(paramList, factoryMapIn, factoryManagersIn);
262 if (factoryName ==
"BlockedGaussSeidelSmoother")
return BuildBlockedSmoother<BlockedGaussSeidelSmoother>(paramList, factoryMapIn, factoryManagersIn);
263 if (factoryName ==
"BlockedJacobiSmoother")
return BuildBlockedSmoother<BlockedJacobiSmoother>(paramList, factoryMapIn, factoryManagersIn);
264 if (factoryName ==
"BlockedPFactory")
return BuildBlockedFactory<BlockedPFactory>(paramList, factoryMapIn, factoryManagersIn);
265 if (factoryName ==
"BraessSarazinSmoother")
return BuildBlockedSmoother<BraessSarazinSmoother>(paramList, factoryMapIn, factoryManagersIn);
266 if (factoryName ==
"IndefiniteBlockDiagonalSmoother")
return BuildBlockedSmoother<IndefBlockedDiagonalSmoother>(paramList, factoryMapIn, factoryManagersIn);
267 if (factoryName ==
"SimpleSmoother")
return BuildBlockedSmoother<SimpleSmoother>(paramList, factoryMapIn, factoryManagersIn);
268 if (factoryName ==
"SchurComplementFactory")
return Build2<SchurComplementFactory>(paramList, factoryMapIn, factoryManagersIn);
269 if (factoryName ==
"RebalanceBlockRestrictionFactory")
return BuildBlockedFactory<RebalanceBlockRestrictionFactory>(paramList, factoryMapIn, factoryManagersIn);
270 if (factoryName ==
"RebalanceBlockAcFactory")
return BuildBlockedFactory<RebalanceBlockAcFactory>(paramList, factoryMapIn, factoryManagersIn);
271 if (factoryName ==
"RebalanceBlockInterpolationFactory")
return BuildBlockedFactory<RebalanceBlockInterpolationFactory>(paramList, factoryMapIn, factoryManagersIn);
273 if (factoryName ==
"RepartitionBlockDiagonalFactory")
return Build2<RepartitionBlockDiagonalFactory>(paramList, factoryMapIn, factoryManagersIn);
275#ifdef HAVE_MUELU_TEKO
276 if (factoryName ==
"TekoSmoother")
return BuildTekoSmoother(paramList, factoryMapIn, factoryManagersIn);
278 if (factoryName ==
"UzawaSmoother")
return BuildBlockedSmoother<UzawaSmoother>(paramList, factoryMapIn, factoryManagersIn);
281#ifdef HAVE_MUELU_MATLAB
282 if (factoryName ==
"SingleLevelMatlabFactory")
return Build2<SingleLevelMatlabFactory>(paramList, factoryMapIn, factoryManagersIn);
283 if (factoryName ==
"TwoLevelMatlabFactory")
return Build2<TwoLevelMatlabFactory>(paramList, factoryMapIn, factoryManagersIn);
284 if (factoryName ==
"MatlabSmoother")
return BuildMatlabSmoother(paramList, factoryMapIn, factoryManagersIn);
287#ifdef HAVE_MUELU_INTREPID2
288 if (factoryName ==
"IntrepidPCoarsenFactory")
return Build2<IntrepidPCoarsenFactory>(paramList, factoryMapIn, factoryManagersIn);
292 if (factoryMapIn.find(factoryName) != factoryMapIn.end()) {
294 "MueLu::FactoryFactory: Error during the parsing of: " << std::endl
295 << paramList << std::endl
296 <<
"'" << factoryName <<
"' is not a factory name but an existing instance of a factory." << std::endl
297 <<
"Extra parameters cannot be specified after the creation of the object." << std::endl
299 <<
"Correct syntaxes includes:" << std::endl
300 <<
" <Parameter name=\"...\" type=\"string\" value=\"" << factoryName <<
"\"/>" << std::endl
302 <<
" <ParameterList name=\"...\"><Parameter name=\"factory\" type=\"string\" value=\"" << factoryName <<
"\"/></ParameterList>" << std::endl);
304 return factoryMapIn.find(factoryName)->second;
307 TEUCHOS_TEST_FOR_EXCEPTION(
true,
Exceptions::RuntimeError,
"MueLu::FactoryFactory: unknown factory name : " << factoryName);
309 TEUCHOS_UNREACHABLE_RETURN(Teuchos::null);
397 if (paramList.isSublist(
"TransferFactories") ==
false) {
399 factory = Build2<T>(paramList, factoryMapIn, factoryManagersIn);
402 RCP<Teuchos::ParameterList> paramListNonConst = rcp(
new Teuchos::ParameterList(paramList));
403 RCP<const Teuchos::ParameterList> transferFactories = rcp(
new Teuchos::ParameterList(*sublist(paramListNonConst,
"TransferFactories")));
405 paramListNonConst->remove(
"TransferFactories");
408 factory = Build2<T>(*paramListNonConst, factoryMapIn, factoryManagersIn);
412 int numProlongatorFactories = 0;
413 int numPtentFactories = 0;
414 int numCoarseNspFactories = 0;
415 for (Teuchos::ParameterList::ConstIterator param = transferFactories->begin(); param != transferFactories->end(); ++param) {
416 size_t foundNsp = transferFactories->name(param).find(
"Nullspace");
417 if (foundNsp != std::string::npos && foundNsp == 0 && transferFactories->name(param).length() == 10) {
418 numCoarseNspFactories++;
421 size_t foundPtent = transferFactories->name(param).find(
"Ptent");
422 if (foundPtent != std::string::npos && foundPtent == 0 && transferFactories->name(param).length() == 6) {
426 size_t foundP = transferFactories->name(param).find(
"P");
427 if (foundP != std::string::npos && foundP == 0 && transferFactories->name(param).length() == 2) {
428 numProlongatorFactories++;
432 TEUCHOS_TEST_FOR_EXCEPTION(numProlongatorFactories != numCoarseNspFactories,
Exceptions::RuntimeError,
"FactoryFactory::BuildToggleP: The user has to provide the same number of prolongator and coarse nullspace factories!");
433 TEUCHOS_TEST_FOR_EXCEPTION(numPtentFactories != numCoarseNspFactories,
Exceptions::RuntimeError,
"FactoryFactory::BuildToggleP: The user has to provide the same number of ptent and coarse nullspace factories!");
434 TEUCHOS_TEST_FOR_EXCEPTION(numProlongatorFactories < 2,
Exceptions::RuntimeError,
"FactoryFactory::BuildToggleP: The TogglePFactory needs at least two different prolongation operators. The factories have to be provided using the names P%i and Nullspace %i, where %i denotes a number between 1 and 9.");
437 std::vector<Teuchos::ParameterEntry> prolongatorFactoryNames(numProlongatorFactories);
438 std::vector<Teuchos::ParameterEntry> coarseNspFactoryNames(numProlongatorFactories);
439 std::vector<Teuchos::ParameterEntry> ptentFactoryNames(numProlongatorFactories);
441 for (Teuchos::ParameterList::ConstIterator param = transferFactories->begin(); param != transferFactories->end(); ++param) {
442 size_t foundNsp = transferFactories->name(param).find(
"Nullspace");
443 if (foundNsp != std::string::npos && foundNsp == 0 && transferFactories->name(param).length() == 10) {
444 int number = atoi(&(transferFactories->name(param).at(9)));
445 TEUCHOS_TEST_FOR_EXCEPTION(number < 1 || number > numProlongatorFactories,
Exceptions::RuntimeError,
"FactoryFactory::BuildToggleP: Please use the format Nullspace%i with %i an integer between 1 and the maximum number of prolongation operators in TogglePFactory!");
446 coarseNspFactoryNames[number - 1] = transferFactories->entry(param);
449 size_t foundPtent = transferFactories->name(param).find(
"Ptent");
450 if (foundPtent != std::string::npos && foundPtent == 0 && transferFactories->name(param).length() == 6) {
451 int number = atoi(&(transferFactories->name(param).at(5)));
452 TEUCHOS_TEST_FOR_EXCEPTION(number < 1 || number > numPtentFactories,
Exceptions::RuntimeError,
"FactoryFactory::BuildToggleP: Please use the format Ptent%i with %i an integer between 1 and the maximum number of prolongation operators in TogglePFactory!");
453 ptentFactoryNames[number - 1] = transferFactories->entry(param);
456 size_t foundP = transferFactories->name(param).find(
"P");
457 if (foundP != std::string::npos && foundP == 0 && transferFactories->name(param).length() == 2) {
458 int number = atoi(&(transferFactories->name(param).at(1)));
459 TEUCHOS_TEST_FOR_EXCEPTION(number < 1 || number > numProlongatorFactories,
Exceptions::RuntimeError,
"FactoryFactory::BuildToggleP: Please use the format P%i with %i an integer between 1 and the maximum number of prolongation operators in TogglePFactory!");
460 prolongatorFactoryNames[number - 1] = transferFactories->entry(param);
466 for (std::vector<Teuchos::ParameterEntry>::const_iterator it = prolongatorFactoryNames.begin(); it != prolongatorFactoryNames.end(); ++it) {
467 RCP<const FactoryBase> p = BuildFactory(*it, factoryMapIn, factoryManagersIn);
468 factory->AddProlongatorFactory(p);
472 for (std::vector<Teuchos::ParameterEntry>::const_iterator it = ptentFactoryNames.begin(); it != ptentFactoryNames.end(); ++it) {
473 RCP<const FactoryBase> p = BuildFactory(*it, factoryMapIn, factoryManagersIn);
474 factory->AddPtentFactory(p);
478 for (std::vector<Teuchos::ParameterEntry>::const_iterator it = coarseNspFactoryNames.begin(); it != coarseNspFactoryNames.end(); ++it) {
479 RCP<const FactoryBase> p = BuildFactory(*it, factoryMapIn, factoryManagersIn);
480 factory->AddCoarseNullspaceFactory(p);