Extend the search with propagators for arbitrary theories.
For an example, see propagator.c.
|
struct | clingo_propagator |
| An instance of this struct has to be registered with a solver to implement a custom propagator. More...
|
|
|
CLINGO_VISIBILITY_DEFAULT uint32_t | clingo_assignment_decision_level (clingo_assignment_t *assignment) |
| Get the current decision level. More...
|
|
CLINGO_VISIBILITY_DEFAULT bool | clingo_assignment_has_conflict (clingo_assignment_t *assignment) |
| Check if the given assignment is conflicting. More...
|
|
CLINGO_VISIBILITY_DEFAULT bool | clingo_assignment_has_literal (clingo_assignment_t *assignment, clingo_literal_t literal) |
| Check if the given literal is part of a (partial) assignment. More...
|
|
CLINGO_VISIBILITY_DEFAULT bool | clingo_assignment_level (clingo_assignment_t *assignment, clingo_literal_t literal, uint32_t *level) |
| Determine the decision level of a given literal. More...
|
|
CLINGO_VISIBILITY_DEFAULT bool | clingo_assignment_decision (clingo_assignment_t *assignment, uint32_t level, clingo_literal_t *literal) |
| Determine the decision literal given a decision level. More...
|
|
CLINGO_VISIBILITY_DEFAULT bool | clingo_assignment_is_fixed (clingo_assignment_t *assignment, clingo_literal_t literal, bool *is_fixed) |
| Check if a literal has a fixed truth value. More...
|
|
CLINGO_VISIBILITY_DEFAULT bool | clingo_assignment_is_true (clingo_assignment_t *assignment, clingo_literal_t literal, bool *is_true) |
| Check if a literal is true. More...
|
|
CLINGO_VISIBILITY_DEFAULT bool | clingo_assignment_is_false (clingo_assignment_t *assignment, clingo_literal_t literal, bool *is_false) |
| Check if a literal has a fixed truth value. More...
|
|
CLINGO_VISIBILITY_DEFAULT bool | clingo_assignment_truth_value (clingo_assignment_t *assignment, clingo_literal_t literal, clingo_truth_value_t *value) |
| Determine the truth value of a given literal. More...
|
|
Represents a (partial) assignment of a particular solver.
An assignment assigns truth values to a set of literals. A literal is assigned to either true or false, or is unassigned. Furthermore, each assigned literal is associated with a decision level. There is exactly one decision literal for each decision level greater than zero. Assignments to all other literals on the same level are consequences implied by the current and possibly previous decisions. Assignments on level zero are immediate consequences of the current program. Decision levels are consecutive numbers starting with zero up to and including the current decision level.
An instance of this struct has to be registered with a solver to implement a custom propagator.
Not all callbacks have to be implemented and can be set to NULL if not needed.
- See also
- Theory Propagation
Enumeration of clause types determining the lifetime of a clause.
Clauses in the solver are either cleaned up based on a configurable deletion policy or at the end of a solving step. The values of this enumeration determine if a clause is subject to one of the above deletion strategies.
Enumerator |
---|
clingo_clause_type_learnt |
clause is subject to the solvers deletion policy
|
clingo_clause_type_static |
clause is not subject to the solvers deletion policy
|
clingo_clause_type_volatile |
like clingo_clause_type_learnt but the clause is deleted after a solving step
|
clingo_clause_type_volatile_static |
like clingo_clause_type_static but the clause is deleted after a solving step
|
Determine the decision literal given a decision level.
- Parameters
-
[in] | assignment | the target assignment |
[in] | level | the level |
[out] | literal | the resulting literal |
- Returns
- whether the call was successful
CLINGO_VISIBILITY_DEFAULT uint32_t clingo_assignment_decision_level |
( |
clingo_assignment_t * |
assignment | ) |
|
Get the current decision level.
- Parameters
-
[in] | assignment | the target assignment |
- Returns
- the decision level
CLINGO_VISIBILITY_DEFAULT bool clingo_assignment_has_conflict |
( |
clingo_assignment_t * |
assignment | ) |
|
Check if the given assignment is conflicting.
- Parameters
-
[in] | assignment | the target assignment |
- Returns
- whether the assignment is conflicting
Check if the given literal is part of a (partial) assignment.
- Parameters
-
[in] | assignment | the target assignment |
[in] | literal | the literal |
- Returns
- whether the literal is valid
Check if a literal has a fixed truth value.
- Parameters
-
[in] | assignment | the target assignment |
[in] | literal | the literal |
[out] | is_false | whether the literal is false |
- Returns
- whether the call was successful
- See also
- clingo_assignment_truth_value()
Check if a literal has a fixed truth value.
- Parameters
-
[in] | assignment | the target assignment |
[in] | literal | the literal |
[out] | is_fixed | whether the literal is fixed |
- Returns
- whether the call was successful
Check if a literal is true.
- Parameters
-
[in] | assignment | the target assignment |
[in] | literal | the literal |
[out] | is_true | whether the literal is true |
- Returns
- whether the call was successful
- See also
- clingo_assignment_truth_value()
Determine the decision level of a given literal.
- Parameters
-
[in] | assignment | the target assignment |
[in] | literal | the literal |
[out] | level | the resulting level |
- Returns
- whether the call was successful
Determine the truth value of a given literal.
- Parameters
-
[in] | assignment | the target assignment |
[in] | literal | the literal |
[out] | value | the resulting truth value |
- Returns
- whether the call was successful
Add the given clause to the solver.
This method sets its result to false if the current propagation must be stopped for the solver to backtrack.
- Attention
- No further calls on the control object or functions on the assignment should be called when the result of this method is false.
- Parameters
-
[in] | control | the target |
[in] | clause | the clause to add |
[in] | size | the size of the clause |
[in] | type | the clause type determining its lifetime |
[out] | result | result indicating whether propagation has to be stopped |
- Returns
- whether the call was successful; might set one of the following error codes:
- Examples:
- propagator.c.
Adds a new volatile literal to the underlying solver thread.
- Attention
- The literal is only valid within the current solving step and solver thread. All volatile literals and clauses involving a volatile literal are deleted after the current search.
- Parameters
-
[in] | control | the target |
[out] | result | the (positive) solver literal |
- Returns
- whether the call was successful; might set one of the following error codes:
Add a watch for the solver literal in the given phase.
- Note
- Unlike clingo_propagate_init_add_watch() this does not add a watch to all solver threads but just the current one.
- Parameters
-
[in] | control | the target |
[in] | literal | the literal to watch |
- Returns
- whether the call was successful; might set one of the following error codes:
- See also
- clingo_propagate_control_remove_watch()
Get the assignment associated with the underlying solver.
- Parameters
-
- Returns
- the assignment
Check whether a literal is watched in the current solver thread.
- Parameters
-
[in] | control | the target |
[in] | literal | the literal to check |
- Returns
- whether the literal is watched
Propagate implied literals (resulting from added clauses).
This method sets its result to false if the current propagation must be stopped for the solver to backtrack.
- Attention
- No further calls on the control object or functions on the assignment should be called when the result of this method is false.
- Parameters
-
[in] | control | the target |
[out] | result | result indicating whether propagation has to be stopped |
- Returns
- whether the call was successful; might set one of the following error codes:
- Examples:
- propagator.c.
Removes the watch (if any) for the given solver literal.
- Note
- Similar to clingo_propagate_init_add_watch() this just removes the watch in the current solver thread.
- Parameters
-
[in] | control | the target |
[in] | literal | the literal to remove |
Get the id of the underlying solver thread.
Thread ids are consecutive numbers starting with zero.
- Parameters
-
- Returns
- the thread id
- Examples:
- propagator.c.
Add a watch for the solver literal in the given phase.
- Parameters
-
[in] | init | the target |
[out] | solver_literal | the solver literal |
- Returns
- whether the call was successful
- Examples:
- propagator.c.
Map the given program literal or condition id to its solver literal.
- Parameters
-
[in] | init | the target |
[in] | aspif_literal | the aspif literal to map |
[out] | solver_literal | the resulting solver literal |
- Returns
- whether the call was successful
- Examples:
- propagator.c.
Get an object to inspect the symbolic atoms.
- Parameters
-
[in] | init | the target |
[out] | atoms | the resulting object |
- Returns
- whether the call was successful
- Examples:
- propagator.c.
Get an object to inspect the theory atoms.
- Parameters
-
[in] | init | the target |
[out] | atoms | the resulting object |
- Returns
- whether the call was successful