10#ifndef MUELU_UNCOUPLEDAGGREGATIONFACTORY_DECL_HPP_
11#define MUELU_UNCOUPLEDAGGREGATIONFACTORY_DECL_HPP_
13#include <Xpetra_Map_fwd.hpp>
14#include <Xpetra_Vector_fwd.hpp>
105#undef MUELU_UNCOUPLEDAGGREGATIONFACTORY_SHORT
121 const std::string& aggAlgo,
122 const bool deterministic,
123 const RCP<const LWGraph_kokkos> graph,
124 RCP<Aggregates> aggregates)
const;
135 SetParameter(
"aggregation: ordering", ParameterEntry(ordering));
139 SetParameter(
"aggregation: max selected neighbors", ParameterEntry(Teuchos::as<LocalOrdinal>(maxNeighAlreadySelected)));
143 SetParameter(
"aggregation: min agg size", ParameterEntry(Teuchos::as<LocalOrdinal>(minNodesPerAggregate)));
146 void SetOnePtMapName(
const std::string name, Teuchos::RCP<const FactoryBase> mapFact) {
147 SetParameter(
"OnePt aggregate map name", ParameterEntry(std::string(name)));
148 SetFactory(
"OnePt aggregate map factory", mapFact);
154 return pL.get<std::string>(
"aggregation: ordering");
159 return Teuchos::as<int>(pL.get<
LocalOrdinal>(
"aggregation: max selected neighbors"));
164 return Teuchos::as<int>(pL.get<
LocalOrdinal>(
"aggregation: min agg size"));
197 mutable std::vector<RCP<MueLu::AggregationAlgorithmBase<LocalOrdinal, GlobalOrdinal, Node> > >
algos_;
208#define MUELU_UNCOUPLEDAGGREGATIONFACTORY_SHORT
MueLu::DefaultLocalOrdinal LocalOrdinal
MueLu::DefaultGlobalOrdinal GlobalOrdinal
virtual void SetFactory(const std::string &varName, const RCP< const FactoryBase > &factory)
Configuration.
Class that holds all level-specific information.
virtual const Teuchos::ParameterList & GetParameterList() const
void SetParameter(const std::string &name, const ParameterEntry &entry)
Set a parameter directly as a ParameterEntry.
Base class for factories that use one level (currentLevel).
Factory for building uncoupled aggregates.
void DeclareInput(Level ¤tLevel) const
Input.
void SetOnePtMapName(const std::string name, Teuchos::RCP< const FactoryBase > mapFact)
void SetMaxNeighAlreadySelected(int maxNeighAlreadySelected)
RCP< const ParameterList > GetValidParameterList() const
Return a const parameter list of valid parameters that setParameterList() will accept.
void Build(Level ¤tLevel) const
Build aggregates.
int GetMaxNeighAlreadySelected() const
int GetMinNodesPerAggregate() const
void SetOrdering(const std::string &ordering)
virtual ~UncoupledAggregationFactory()
Destructor.
void SetMinNodesPerAggregate(int minNodesPerAggregate)
void DoGraphColoring(Level ¤tLevel, const std::string &aggAlgo, const bool deterministic, const RCP< const LWGraph_kokkos > graph, RCP< Aggregates > aggregates) const
UncoupledAggregationFactory()
Constructor.
const std::string & GetOrdering() const
std::vector< RCP< MueLu::AggregationAlgorithmBase< LocalOrdinal, GlobalOrdinal, Node > > > algos_
Append a new aggregation algorithm to list of aggregation algorithms.
Namespace for MueLu classes and methods.
Tpetra::KokkosClassic::DefaultNode::DefaultNodeType DefaultNode