Class StaticUserDefinedPredicateFactory
- All Implemented Interfaces:
PredicateFactory, UserDefinedPredicateFactory
A "static" user defined predicate is one that can not have clauses added or removed after it is first defined.
-
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()getClauseModel(int index) Returns the clause at the specified position in this predicate's list of clauses.org.projog.core.predicate.udp.ImplicationsIteratorReturns an iterator over the clauses of this user defined predicate.getPredicate(Term term) Returns aPredicateto be used in the evaluation of a goal.Returns the key for the predicate this object representsbooleanReturnstrueis this predicate is dynamic.booleanShould instances of this implementation be re-evaluated when backtracking?preprocess(Term arg) Methods inherited from class Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface PredicateFactory
isAlwaysCutOnBacktrack
-
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()- Specified by:
compilein interfaceUserDefinedPredicateFactory
-
getPredicate
Description copied from interface:PredicateFactoryReturns aPredicateto be used in the evaluation of a goal.- Specified by:
getPredicatein interfacePredicateFactory- Parameters:
term- the term containing 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
-
getImplications
public org.projog.core.predicate.udp.ImplicationsIterator 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 interfacePredicateFactory
-