Class StaticUserDefinedPredicateFactory
- All Implemented Interfaces:
PredicateFactory, PreprocessablePredicateFactory, UserDefinedPredicateFactory
A "static" user defined predicate is one that can not have clauses added or removed after it is first defined.
-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionprivate static final classprivate static final classprivate final classprivate final classprivate final classprivate final class -
Field Summary
FieldsModifier and TypeFieldDescriptionprivate PredicateFactoryprivate final List<ClauseModel> private final KnowledgeBaseprivate final Objectprivate final PredicateKeyprivate intprivate final SpyPoints.SpyPoint -
Constructor Summary
ConstructorsConstructorDescriptionStaticUserDefinedPredicateFactory(KnowledgeBase kb, PredicateKey predicateKey) -
Method Summary
Modifier and TypeMethodDescriptionvoidaddFirst(ClauseModel clauseModel) Not supported.voidaddLast(ClauseModel clauseModel) Adds new clause to list of clauses for this predicate.voidcompile()private PredicateFactorycreateInterpretedPredicateFactoryFromClauseActions(Clauses clauses, List<ClauseModel> clauseModels) private PredicateFactoryprivate PredicatecreatePredicate(Term[] args, ClauseAction[] clauses) private PredicateFactorygetClauseModel(int index) Returns the clause at the specified position in this predicate's list of clauses.private List<ClauseModel> Returns an iterator over the clauses of this user defined predicate.getPredicate(Term[] args) Returns aPredicateto be used in the evaluation of a goal.Returns the key for the predicate this object representsprivate static booleanisClausesRetryable(ClauseAction[] clauses) Returns true if clauses could return more than one result.private booleanisCyclic()Returntrueif this predicate calls a predicate that in turns calls this predicate.booleanReturnstrueis this predicate is dynamic.booleanShould instances of this implementation be re-evaluated when backtracking?private static List<ClauseAction> optimisePredicateFactory(KnowledgeBase kb, ClauseAction[] data, Term arg) preprocess(Term arg) private voidMethods inherited from class Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface PredicateFactory
isAlwaysCutOnBacktrack
-
Field Details
-
lock
-
predicateKey
-
kb
-
spyPoint
-
implications
-
compiledPredicateFactory
-
setCompiledPredicateFactoryInvocationCtr
private int setCompiledPredicateFactoryInvocationCtr
-
-
Constructor Details
-
StaticUserDefinedPredicateFactory
-
-
Method Details
-
addFirst
Not supported.It is not possible to add a clause to the beginning of a static user defined predicate.
- Specified by:
addFirstin interfaceUserDefinedPredicateFactory- Parameters:
clauseModel- the clause to add to the beginning of the predicate- Throws:
ProjogException
-
addLast
Adds new clause to list of clauses for this predicate.Note: it is not possible to add clauses to a static user defined predicate once it has been compiled.
- Specified by:
addLastin interfaceUserDefinedPredicateFactory- Parameters:
clauseModel- the clause to add to the end of the predicate- Throws:
IllegalStateException- if the predicate has already been compiled.
-
compile
public void compile() -
setCompiledPredicateFactory
private void setCompiledPredicateFactory() -
getCopyOfImplications
-
isCyclic
private boolean isCyclic()Returntrueif this predicate calls a predicate that in turns calls this predicate.For example, in the following script both
aandbare cyclic, butcis not.a(Z) :- b(Z). b(Z) :- a(Z). c(Z) :- b(Z).
-
createInterpretedPredicateFactoryFromClauseActions
private PredicateFactory createInterpretedPredicateFactoryFromClauseActions(Clauses clauses, List<ClauseModel> clauseModels) -
createInterpretedPredicateFactoryFromClauses
-
createSingleClausePredicateFactory
-
createPredicate
-
isClausesRetryable
Returns true if clauses could return more than one result.Returns false if use of cut means once a result has been found a subsequent attempt at backtracking will immediately fail. e.g.:
p(X) :- var(X), !. p(1) :- !. p(7). % OK for last rule not to contain a cut, as long as it is not retryable.
-
getPredicate
Description copied from interface:PredicateFactoryReturns aPredicateto be used in the evaluation of a goal.- Specified by:
getPredicatein interfacePredicateFactory- Parameters:
args- the arguments to use in the evaluation of the goal- Returns:
- Predicate to be used in the evaluation of the goal
- See Also:
-
getPredicateKey
Description copied from interface:UserDefinedPredicateFactoryReturns the key for the predicate this object represents- Specified by:
getPredicateKeyin interfaceUserDefinedPredicateFactory- Returns:
- the key for the predicate this object represents
-
getActualPredicateFactory
-
getImplications
Returns an iterator over the clauses of this user defined predicate.The iterator returned will have the following characteristics which prevent the underlying structure of the user defined predicate being altered:
- Calls to
Iterator.next()return a new copy of theClauseModel. - Calls to
Iterator.remove()cause aUnsupportedOperationException
- Specified by:
getImplicationsin interfaceUserDefinedPredicateFactory- Returns:
- an iterator over the clauses in the predicate in proper sequence.
- Calls to
-
isDynamic
public boolean isDynamic()Description copied from interface:UserDefinedPredicateFactoryReturnstrueis this predicate is dynamic.A "dynamic" predicate is a user defined predicate that can have clauses added or removed after is first defined.
- Specified by:
isDynamicin interfaceUserDefinedPredicateFactory- Returns:
trueis this predicate is dynamic
-
getClauseModel
Description copied from interface:UserDefinedPredicateFactoryReturns the clause at the specified position in this predicate's list of clauses.- Specified by:
getClauseModelin interfaceUserDefinedPredicateFactory- Parameters:
index- index of the clause to return- Returns:
- the clause at the specified position in this predicate's list of clauses or
nullif out of bounds
-
isRetryable
public boolean isRetryable()Description copied from interface:PredicateFactoryShould instances of this implementation be re-evaluated when backtracking?Some goals (e.g.
X is 1) are only meant to be evaluated once (the statement is either true or false) while others (e.g.repeat(3)) are meant to be evaluated multiple times. For instances ofPredicatethat are designed to possibly havePredicate.evaluate()called on them multiple times for the same individual query this method should returntrue. For instances ofPredicatethat are designed to only be evaluated once per individual query this method should returnfalse.- Specified by:
isRetryablein interfacePredicateFactory- Returns:
trueif an attempt should be made to re-evaluate instances of implementing classes when backtracking,falseotherwise
-
preprocess
- Specified by:
preprocessin interfacePreprocessablePredicateFactory
-
optimisePredicateFactory
private static List<ClauseAction> optimisePredicateFactory(KnowledgeBase kb, ClauseAction[] data, Term arg)
-