17 : _fe_problem(fe_problem)
23 : _fe_problem(x._fe_problem)
38 for (
const auto & elem : range)
40 const unsigned int n_nodes = elem->n_nodes();
44 std::set<SubdomainID> block_ids;
45 for (
unsigned int n = 0; n <
n_nodes; n++)
47 auto node = elem->node_ptr(n);
49 block_ids.insert(ids.begin(), ids.end());
55 std::vector<MooseVariableFEBase *> order;
64 std::map<MooseVariableFEBase *, std::vector<std::shared_ptr<InitialConditionBase>>> groups;
65 for (
auto id : block_ids)
69 if ((
id != elem->subdomain_id() && !ic->variable().isNodal()) ||
70 ic->getState() != current_ic_state)
72 order.push_back(&(ic->variable()));
73 groups[&(ic->variable())].push_back(ic);
80 for (
auto var : order)
83 auto & vec = groups[var];
90 DependencyResolverInterface::sort<std::shared_ptr<InitialConditionBase>>(vec);
94 DependencyResolverInterface::cyclicDependencyError<std::shared_ptr<InitialConditionBase>>(
95 e,
"Cyclic dependency detected in object ordering");
103 var->insert(var->sys().solution());
121 console <<
"[DBG] Executing initial conditions on elements on " << execute_on << std::endl;
122 console <<
"[DBG] Unordered list:" << std::endl;
123 console << ic_wh.activeObjectsToFormattedString() << std::endl;
124 console <<
"[DBG] The order of execution is defined by dependency resolution on every element" unsigned short getCurrentICState()
Retrieves the current initial condition state.
bool hasActiveBlockObjects(THREAD_ID tid=0) const
const std::map< SubdomainID, std::vector< std::shared_ptr< T > > > & getActiveBlockObjects(THREAD_ID tid=0) const
virtual void prepare(const Elem *elem, const THREAD_ID tid) override
Warehouse for storing initial conditions.
const ExecFlagType & getCurrentExecuteOnFlag() const
Return/set the current execution flag.
void printGeneralExecutionInformation() const
Print information about the loop, mostly order of execution of objects.
const std::set< SubdomainID > & getNodeBlockIds(const Node &node) const
Return list of blocks to which the given node belongs.
const InitialConditionWarehouse & getInitialConditionWarehouse() const
Return InitialCondition storage.
ComputeInitialConditionThread(FEProblemBase &fe_problem)
Specialization of SubProblem for solving nonlinear equations plus auxiliary equations.
const dof_id_type n_nodes
bool shouldPrintExecution(const THREAD_ID tid) const
Check whether the problem should output execution orders at this time.
virtual void reinitElem(const Elem *elem, const THREAD_ID tid) override
virtual void setCurrentSubdomainID(const Elem *elem, const THREAD_ID tid) override
const ConsoleStream & console() const
Return console handle.
virtual MooseMesh & mesh() override
void operator()(const libMesh::ConstElemRange &range)
void join(const ComputeInitialConditionThread &)
FEProblemBase & _fe_problem