3#include <clingo/ground/literal.hh>
5#include <clingo/ground/instantiator.hh>
7#include <clingo/core/core.hh>
9#include <memory_resource>
11namespace CppClingo::Ground {
20 [[nodiscard]]
auto body() const ->
ULitVec const & {
return do_body(); }
30 friend auto operator<<(std::ostream &out,
Stm const &stm) -> std::ostream & {
36 virtual void do_print(std::ostream &out)
const = 0;
37 [[nodiscard]]
virtual auto do_body() const ->
ULitVec const & = 0;
38 [[nodiscard]] virtual auto do_important() const ->
VariableSet = 0;
50 Linearizer(std::pmr::monotonic_buffer_resource &mbr) : mbr_{&mbr} {}
58 void build_(
ULitVec const &lits);
61 ULitVec const &lits) -> std::pair<Instantiator, std::optional<size_t>>;
63 Queue *iqueue_ =
nullptr;
64 std::pmr::monotonic_buffer_resource *mbr_;
65 std::vector<size_t> rec_;
66 std::vector<std::vector<MatcherType>> todos_;
67 std::vector<std::tuple<size_t, size_t, double>> queue_;
69 std::vector<std::tuple<size_t, std::vector<size_t>, std::vector<size_t>>> lit_map_;
71 std::vector<std::vector<size_t>> var_map_;
85 : head_{head ? std::move(std::get<0>(*head)) : nullptr}, base_{head ? &std::get<1>(*head) : nullptr},
86 indices_{head ? std::move(std::get<2>(*head)) : std::vector<size_t>{}}, body_{std::move(
body)}, type_{type} {
94 void do_print(std::ostream &out)
const override;
95 [[nodiscard]]
auto do_body() const ->
ULitVec const & override;
96 [[nodiscard]] auto do_important() const ->
VariableSet override;
99 void do_print_head(std::ostream &out) const override;
100 void do_init(
size_t gen) override;
101 [[nodiscard]] auto do_report(EvalContext const &ctx) ->
bool override;
102 void do_propagate(SymbolStore &store, OutputStm &out, Queue &queue) override;
103 [[nodiscard]] auto do_priority() const ->
size_t override {
return std::numeric_limits<size_t>::max(); }
114 std::vector<size_t> indices_;
125 std::optional<std::pair<Location, UTerm>> type)
126 : type_{std::move(type)}, atom_{std::move(atom)}, base_{&base}, indices_{std::move(indices)},
127 body_{std::move(
body)} {
135 void do_print(std::ostream &out)
const override;
136 [[nodiscard]]
auto do_body() const ->
ULitVec const & override;
137 [[nodiscard]] auto do_important() const ->
VariableSet override;
140 void do_print_head(std::ostream &out) const override;
141 void do_init(
size_t gen) override;
142 [[nodiscard]] auto do_report(
EvalContext const &ctx) ->
bool override;
144 [[nodiscard]] auto do_priority() const ->
size_t override {
return std::numeric_limits<size_t>::max(); }
145 [[nodiscard]]
auto do_is_important([[maybe_unused]]
size_t index)
const ->
bool override {
return false; }
147 std::optional<std::pair<Location, UTerm>> type_;
157 std::vector<size_t> indices_;
169 : loc_weight_{std::move(loc_weight)}, loc_prio_{prio ? std::move(prio->first) : loc_weight_},
170 weight_{std::move(weight)}, prio_{prio ? std::move(prio->second) : nullptr}, terms_{std::move(terms)},
171 body_{std::move(
body)} {
178 void do_print(std::ostream &out)
const override;
179 [[nodiscard]]
auto do_body() const ->
ULitVec const & override;
180 [[nodiscard]] auto do_important() const ->
VariableSet override;
183 void do_print_head(std::ostream &out) const override;
184 void do_init(
size_t gen) override;
185 [[nodiscard]] auto do_report(
EvalContext const &ctx) ->
bool override;
187 [[nodiscard]] auto do_priority() const ->
size_t override {
return std::numeric_limits<size_t>::max(); }
196 std::optional<Symbol> res_prio_;
205 std::optional<std::pair<Location, UTerm>> prio,
Location loc_type,
UTerm type)
206 : loc_weight_{std::move(loc_weight)}, loc_prio_{prio ? std::move(prio->first) : loc_weight_},
207 loc_type_{std::move(loc_type)}, atom_{std::move(atom)}, base_{&base}, weight_{std::move(weight)},
208 prio_{prio ? std::move(prio->second) : nullptr}, type_{std::move(type)}, body_{std::move(
body)} {
215 void do_print(std::ostream &out)
const override;
216 [[nodiscard]]
auto do_body() const ->
ULitVec const & override;
217 [[nodiscard]] auto do_important() const ->
VariableSet override;
220 void do_print_head(std::ostream &out) const override;
221 void do_init(
size_t gen) override;
222 [[nodiscard]] auto do_report(
EvalContext const &ctx) ->
bool override;
224 [[nodiscard]] auto do_priority() const ->
size_t override {
return std::numeric_limits<size_t>::max(); }
252 void do_print(std::ostream &out)
const override;
253 [[nodiscard]]
auto do_body() const ->
ULitVec const & override;
254 [[nodiscard]] auto do_important() const ->
VariableSet override;
257 void do_print_head(std::ostream &out) const override;
258 void do_init(
size_t gen) override;
259 [[nodiscard]] auto do_report(
EvalContext const &ctx) ->
bool override;
261 [[nodiscard]] auto do_priority() const ->
size_t override {
return std::numeric_limits<size_t>::max(); }
279 void do_print(std::ostream &out)
const override;
280 [[nodiscard]]
auto do_body() const ->
ULitVec const & override;
281 [[nodiscard]] auto do_important() const ->
VariableSet override;
284 void do_print_head(std::ostream &out) const override;
285 void do_init(
size_t gen) override;
286 [[nodiscard]] auto do_report(
EvalContext const &ctx) ->
bool override;
288 [[nodiscard]] auto do_priority() const ->
size_t override {
return std::numeric_limits<size_t>::max(); }
300 : atom_{std::move(atom)}, base_{&base}, body_{std::move(
body)} {
307 void do_print(std::ostream &out)
const override;
308 [[nodiscard]]
auto do_body() const ->
ULitVec const & override;
309 [[nodiscard]] auto do_important() const ->
VariableSet override;
312 void do_print_head(std::ostream &out) const override;
313 void do_init(
size_t gen) override;
314 [[nodiscard]] auto do_report(
EvalContext const &ctx) ->
bool override;
316 [[nodiscard]] auto do_priority() const ->
size_t override {
return std::numeric_limits<size_t>::max(); }
317 [[nodiscard]]
auto do_is_important([[maybe_unused]]
size_t index)
const ->
bool override {
return false; }
An atom base used to store derivable atoms and associated state.
Definition base.hh:212
Context object to capture state used during instantiation.
Definition instantiator.hh:35
Callbacks to notify statements during instantiations.
Definition instantiator.hh:107
Helper class to prepare statements for grounding.
Definition statement.hh:47
void start(Queue &queue)
Indicate that a new domain is being prepared.
void prepare(InstanceCallback &cb, ULitVec const &body, VariableSet important)
Prepare a statement for grounding.
Linearizer(std::pmr::monotonic_buffer_resource &mbr)
Construct the linearizer.
Definition statement.hh:50
A queue to process instantiators.
Definition instantiator.hh:206
A statement edge directives.
Definition statement.hh:242
StmEdge(UTerm src, UTerm dst, ULitVec body)
Construct the statement.
Definition statement.hh:245
A statement capturing normal rules and integrity constraints.
Definition statement.hh:121
StmExternal(Ground::UTerm atom, AtomBase &base, std::vector< size_t > indices, ULitVec body, std::optional< std::pair< Location, UTerm > > type)
Construct the statement.
Definition statement.hh:124
Statement capturing heuristic directives.
Definition statement.hh:201
StmHeuristic(UTerm atom, AtomBase &base, ULitVec body, Location loc_weight, UTerm weight, std::optional< std::pair< Location, UTerm > > prio, Location loc_type, UTerm type)
Construct the statement.
Definition statement.hh:204
Statement capturing project directives.
Definition statement.hh:296
StmProject(UTerm atom, AtomBase &base, ULitVec body)
Construct the statement.
Definition statement.hh:299
A statement capturing normal rules and integrity constraints.
Definition statement.hh:81
StmRule(AtomSimple head, ULitVec body, RuleType type)
Construct the statement.
Definition statement.hh:84
A statement for show directives.
Definition statement.hh:271
StmShow(UTerm term, ULitVec body)
Construct the statement.
Definition statement.hh:274
A statement capturing weak constraints.
Definition statement.hh:164
StmWeakConstraint(Location loc_weight, UTerm weight, std::optional< std::pair< Location, UTerm > > prio, UTermVec terms, ULitVec body)
Construct the statement.
Definition statement.hh:167
Base class for groundable statements.
Definition statement.hh:17
auto important() const -> VariableSet
Get the important variables in the statement.
Definition statement.hh:27
friend auto operator<<(std::ostream &out, Stm const &stm) -> std::ostream &
Print the statement.
Definition statement.hh:30
auto body() const -> ULitVec const &
Get the body of the statement.
Definition statement.hh:20
The Location of an expression in an input source.
Definition location.hh:44
Interface to output statements.
Definition output.hh:90
A store for symbols.
Definition symbol.hh:454
static auto sup() noexcept -> Symbol
Construct the infimum constant (#inf).
Variant-like class to store symbols stored in a symbol store.
Definition symbol.hh:225
std::vector< Symbol > SymbolVec
A vector of symbols.
Definition symbol.hh:220
HeuristicType
Available heuristic types.
Definition core.hh:172
ExternalType
Available external types.
Definition core.hh:177
Util::ordered_set< size_t > VariableSet
A set of variables.
Definition base.hh:19
std::optional< std::tuple< Ground::UTerm, AtomBase &, std::vector< size_t > > > AtomSimple
Represents a simple head literal which is either represented by a symbol term or #false captured by s...
Definition literal.hh:231
std::vector< ULit > ULitVec
A vector of literals.
Definition literal.hh:31
std::vector< UStm > UStmVec
A vector of statements.
Definition statement.hh:44
std::unique_ptr< Stm > UStm
A unique pointer holding a statement.
Definition statement.hh:42
RuleType
Enumeration of available rule types.
Definition statement.hh:75
std::unique_ptr< Term > UTerm
A unique pointer holding a term.
Definition term.hh:33
std::vector< UTerm > UTermVec
A vector of terms.
Definition term.hh:35