44 for (
const auto & elem : range)
46 const unsigned int n_nodes = elem->n_nodes();
50 std::set<SubdomainID> block_ids;
51 for (
unsigned int n = 0; n <
n_nodes; n++)
53 auto node = elem->node_ptr(n);
55 block_ids.insert(ids.begin(), ids.end());
61 std::vector<MooseVariableFEBase *> order;
70 std::map<MooseVariableFEBase *, std::vector<std::shared_ptr<InitialConditionBase>>> groups;
71 for (
auto id : block_ids)
75 if ((
id != elem->subdomain_id() && !ic->variable().isNodal()) ||
76 ic->getState() != current_ic_state)
80 const auto & var_name = ic->variable().name();
84 order.push_back(&(ic->variable()));
85 groups[&(ic->variable())].push_back(ic);
92 for (
auto var : order)
95 auto & vec = groups[var];
102 DependencyResolverInterface::sort<std::shared_ptr<InitialConditionBase>>(vec);
106 DependencyResolverInterface::cyclicDependencyError<std::shared_ptr<InitialConditionBase>>(
107 e,
"Cyclic dependency detected in object ordering");
115 var->insert(var->sys().solution());
const std::set< VariableName > * _target_vars
the names of target variables for which the initial conditions are applied
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.
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.
const dof_id_type n_nodes
virtual void reinitElem(const Elem *elem, const THREAD_ID tid) override
virtual void setCurrentSubdomainID(const Elem *elem, const THREAD_ID tid) override
virtual MooseMesh & mesh() override
FEProblemBase & _fe_problem