Class Resolve.ClpResolvePredicate
- java.lang.Object
-
- org.projog.core.predicate.builtin.clp.Resolve.ClpResolvePredicate
-
-
Field Summary
Fields Modifier and Type Field Description private org.projog.clp.BruteForceSearchbruteForceSearchprivate java.util.Map<ClpVariable,org.projog.clp.Variable>variables
-
Constructor Summary
Constructors Modifier Constructor Description privateClpResolvePredicate(org.projog.clp.BruteForceSearch bruteForceSearch, java.util.Map<ClpVariable,org.projog.clp.Variable> variables)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description booleancouldReevaluationSucceed()Could the next re-evaluation of this instance succeed?booleanevaluate()Attempts to satisfy the goal this instance represents.private org.projog.clp.ClpConstraintStorenext()
-
-
-
Field Detail
-
bruteForceSearch
private final org.projog.clp.BruteForceSearch bruteForceSearch
-
variables
private final java.util.Map<ClpVariable,org.projog.clp.Variable> variables
-
-
Constructor Detail
-
ClpResolvePredicate
private ClpResolvePredicate(org.projog.clp.BruteForceSearch bruteForceSearch, java.util.Map<ClpVariable,org.projog.clp.Variable> variables)
-
-
Method Detail
-
evaluate
public boolean evaluate()
Description copied from interface:PredicateAttempts to satisfy the goal this instance represents.Calling this method multiple times on a single instance allows all possible answers to be identified. An attempt to find a solution carries on from where the last successful call finished.
If
PredicateFactory.isRetryable()returnsfalsethen this method should only be called once per individual query (no attempt should be made to find alternative solutions).If
PredicateFactory.isRetryable()returnstruethen, in order to find all possible solutions for an individual query, this method should be recalled on backtracking until it returnsfalse.- Specified by:
evaluatein interfacePredicate- Returns:
trueif it was possible to satisfy the clause,falseotherwise- See Also:
PredicateFactory.getPredicate(Term[])
-
next
private org.projog.clp.ClpConstraintStore next()
-
couldReevaluationSucceed
public boolean couldReevaluationSucceed()
Description copied from interface:PredicateCould the next re-evaluation of this instance succeed?Specifies whether a specific instance of a specific implementation of
Predicate, that has already hadPredicate.evaluate()called on it at least once, could possibly returntruethe next timePredicate.evaluate()is called on it. i.e. is it worth trying to continue to find solutions for the specific query this particular instance represents and has been evaluating?(Note: the difference between this method and
PredicateFactory.isRetryable()is thatPredicateFactory.isRetryable()deals with whether, in general, a specific implementation (rather than instance) ofPredicatecould ever produce multiple answers for an individual query.)- Specified by:
couldReevaluationSucceedin interfacePredicate- Returns:
trueif an attempt to re-evaluate this instance could possible succeed,falseotherwise
-
-