Class DynamicUserDefinedPredicateFactory
- All Implemented Interfaces:
PredicateFactory, UserDefinedPredicateFactory
A "dynamic" user defined predicate is one that can have clauses added and removed after it has been first
defined. This is normally done using the asserta/1, assertz/1 and retract/1 predicates.
- See Also:
-
Constructor Summary
ConstructorsConstructorDescriptionDynamicUserDefinedPredicateFactory(KnowledgeBase kb, PredicateKey predicateKey) -
Method Summary
Modifier and TypeMethodDescriptionvoidaddFirst(ClauseModel clauseModel) Adds a clause to the beginning of the predicate's list of clauses.voidaddLast(ClauseModel clauseModel) Adds a clause to the end of the predicate's list of clauses.voidcompile()getClauseModel(int index) Returns the clause at the specified position in this predicate's list of clauses.Returns 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?Methods inherited from class Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface PredicateFactory
isAlwaysCutOnBacktrack, preprocess
-
Constructor Details
-
DynamicUserDefinedPredicateFactory
-
-
Method Details
-
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
-
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
-
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
-
compile
public void compile()- Specified by:
compilein interfaceUserDefinedPredicateFactory
-
getImplications
Returns an iterator over the clauses of this user defined predicate.The iterator returned will have the following characteristics:
- Calls to
Iterator.next()return a new copy of theClauseModelto avoid the original being altered. - Calls to
Iterator.remove()do alter the underlying structure of this user defined predicate.
- Specified by:
getImplicationsin interfaceUserDefinedPredicateFactory- Returns:
- an iterator over the clauses in the predicate in proper sequence.
- Calls to
-
addFirst
Description copied from interface:UserDefinedPredicateFactoryAdds a clause to the beginning of the predicate's list of clauses.- Specified by:
addFirstin interfaceUserDefinedPredicateFactory- Parameters:
clauseModel- the clause to add to the beginning of the predicate
-
addLast
Description copied from interface:UserDefinedPredicateFactoryAdds a clause to the end of the predicate's list of clauses.- Specified by:
addLastin interfaceUserDefinedPredicateFactory- Parameters:
clauseModel- the clause to add to the end of the predicate
-
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
-