Package org.tweetyproject.lp.asp.syntax
Class AggregateAtom
- java.lang.Object
-
- org.tweetyproject.lp.asp.syntax.ASPElement
-
- org.tweetyproject.lp.asp.syntax.ASPBodyElement
-
- org.tweetyproject.lp.asp.syntax.AggregateAtom
-
- All Implemented Interfaces:
Formula,ComplexLogicalFormula,LogicStructure,SimpleLogicalFormula
public class AggregateAtom extends ASPBodyElement
This class represents an aggregate. Aggregates are functions that range over sets of terms and literals and evaluate to some value. For example, using the aggregate function #count one can easily express "the number of employees of a department has to be greater than 0".
An aggregate function together with the terms and literals it ranges over and a comparison (like >= 0) is called an aggregate atom and can appear in the body of a rule.
If you want to use an aggregate atom as the head of a rule (as is allowed in some standards like clingo), useAggregateHead- Author:
- Tim Janus, Thomas Vengels, Anna Gessler
-
-
Constructor Summary
Constructors Constructor Description AggregateAtom()Empty default constructor.AggregateAtom(java.util.List<ASPBodyElement> literals, int leftBound, int rightBound)Creates a new cardinality rule, meaning an aggregate of the form "leftBound <= #count { elements } <= rightBound" with the given literals and the given integer bounds.AggregateAtom(AggregateAtom other)Copy-ConstructorAggregateAtom(ASPOperator.AggregateFunction function, java.util.List<AggregateElement> elements)Creates a new Aggregate with the given aggregate function and the given aggregate elements.AggregateAtom(ASPOperator.AggregateFunction function, java.util.List<AggregateElement> elements, ASPOperator.BinaryOperator rightRelation, int rightBound)Creates a new Aggregate of the form "#func { elements } op rightBound" with the given aggregate function #func, the given aggregate elements, the given aggregate relation op and the given rightBound.AggregateAtom(ASPOperator.AggregateFunction function, java.util.List<AggregateElement> elements, ASPOperator.BinaryOperator leftRelation, int leftBound, ASPOperator.BinaryOperator rightRelation, int rightBound)Creates a new Aggregate of the form "leftBound op #func { elements } op rightBound" with the given aggregate function, the given aggregate elements, and the given left and right aggregate relations and integer bounds.AggregateAtom(ASPOperator.AggregateFunction function, java.util.List<AggregateElement> elements, ASPOperator.BinaryOperator rightRelation, Term<?> rightBound)Creates a new Aggregate of the form "#func { elements } op rightBound" with the given aggregate function #func, the given aggregate elements, the given aggregate relation op and the given rightBound.AggregateAtom(ASPOperator.AggregateFunction function, java.util.List<AggregateElement> elements, ASPOperator.BinaryOperator leftRelation, Term<?> leftBound, ASPOperator.BinaryOperator rightRelation, Term<?> rightBound)Creates a new Aggregate of the form "leftBound leftOp #func { elements } rightOp rightBound" with the given aggregate function, the given aggregate elements, and the given left and right aggregate relations and bounds.
-
Method Summary
Modifier and Type Method Description AggregateAtomclone()Creates a deep copy of this formulajava.util.List<AggregateElement>getAggregateElements()java.util.Set<ASPAtom>getAtoms()Processes the set of all atoms which appear in this formulaASPOperator.AggregateFunctiongetFunction()Term<?>getLeftGuard()Get the left relation term (right guard).ASPOperator.BinaryOperatorgetLeftOperator()Returns the operator of the left aggregate relation.java.util.SortedSet<ASPLiteral>getLiterals()Returns all literals in this element in form of a SortedSet.java.util.Set<Predicate>getPredicates()Processes the set of all predicates which appear in this formulaTerm<?>getRightGuard()ASPOperator.BinaryOperatorgetRightOperator()Returns the operator of the right aggregate relation.FolSignaturegetSignature()Returns the signature of the language of this formula.java.util.Set<Term<?>>getTerms()<C extends Term<?>>
java.util.Set<C>getTerms(java.lang.Class<C> cls)Processes the set containing all terms of type C.booleanhasLeftRelation()Returns true if the aggregate has a left aggregate relation (meaning a term that the aggregate's resulting value will be compared to using a comparative operator).booleanhasRightRelation()Returns true if the aggregate has a right aggregate relation (meaning a term that the aggregate's resulting value will be compared to using a comparative operator).booleanisLiteral()java.lang.StringprintToClingo()Returns a representation of this ASP element in clingo (potassco) syntax.voidsetFunction(ASPOperator.AggregateFunction function)Sets the aggregate function.voidsetLeft(Term<?> term, ASPOperator.BinaryOperator op)Set the left relation term and operator.voidsetLeftGuard(Term<?> relationTerm)Set the left relation term (right guard).voidsetLeftOperator(ASPOperator.BinaryOperator op)Sets the operator of the left aggregate relation.voidsetRight(Term<?> term, ASPOperator.BinaryOperator op)Set the right relation term and operator.voidsetRightGuard(Term<?> relationTerm)Set the right relation term (right guard).voidsetRightOperator(ASPOperator.BinaryOperator op)Sets the operator of the right aggregate relation.AggregateAtomsubstitute(Term<?> t, Term<?> v)Substitutes all occurrences of term "v" in this formula by term "t" and returns the new formula.java.lang.StringtoString()-
Methods inherited from class org.tweetyproject.lp.asp.syntax.ASPElement
containsTermsOfType, exchange, getPredicateCls, isGround, isWellFormed, substitute
-
Methods inherited from class java.lang.Object
equals, getClass, hashCode, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface org.tweetyproject.logics.commons.syntax.interfaces.SimpleLogicalFormula
equals, hashCode
-
-
-
-
Constructor Detail
-
AggregateAtom
public AggregateAtom()
Empty default constructor.
-
AggregateAtom
public AggregateAtom(ASPOperator.AggregateFunction function, java.util.List<AggregateElement> elements)
Creates a new Aggregate with the given aggregate function and the given aggregate elements.- Parameters:
function- an aggregate functionelements- list of aggregate elements
-
AggregateAtom
public AggregateAtom(ASPOperator.AggregateFunction function, java.util.List<AggregateElement> elements, ASPOperator.BinaryOperator rightRelation, Term<?> rightBound)
Creates a new Aggregate of the form "#func { elements } op rightBound" with the given aggregate function #func, the given aggregate elements, the given aggregate relation op and the given rightBound.- Parameters:
function- an aggregate functionelements- list of aggregate elementsrightRelation- the relationrightBound- some term
-
AggregateAtom
public AggregateAtom(ASPOperator.AggregateFunction function, java.util.List<AggregateElement> elements, ASPOperator.BinaryOperator rightRelation, int rightBound)
Creates a new Aggregate of the form "#func { elements } op rightBound" with the given aggregate function #func, the given aggregate elements, the given aggregate relation op and the given rightBound.- Parameters:
function- an aggregate functionelements- list of aggregate elementsrightRelation- the relationrightBound- integer
-
AggregateAtom
public AggregateAtom(ASPOperator.AggregateFunction function, java.util.List<AggregateElement> elements, ASPOperator.BinaryOperator leftRelation, Term<?> leftBound, ASPOperator.BinaryOperator rightRelation, Term<?> rightBound)
Creates a new Aggregate of the form "leftBound leftOp #func { elements } rightOp rightBound" with the given aggregate function, the given aggregate elements, and the given left and right aggregate relations and bounds.- Parameters:
function- an aggregate functionelements- list of aggregate elementsleftRelation-leftBound- termrightRelation-rightBound- term
-
AggregateAtom
public AggregateAtom(ASPOperator.AggregateFunction function, java.util.List<AggregateElement> elements, ASPOperator.BinaryOperator leftRelation, int leftBound, ASPOperator.BinaryOperator rightRelation, int rightBound)
Creates a new Aggregate of the form "leftBound op #func { elements } op rightBound" with the given aggregate function, the given aggregate elements, and the given left and right aggregate relations and integer bounds.- Parameters:
function- an aggregate functionelements- list of aggregate elementsleftRelation-leftBound- integerrightRelation-rightBound- integer
-
AggregateAtom
public AggregateAtom(java.util.List<ASPBodyElement> literals, int leftBound, int rightBound)
Creates a new cardinality rule, meaning an aggregate of the form "leftBound <= #count { elements } <= rightBound" with the given literals and the given integer bounds.- Parameters:
literals- of the cardinality ruleleftBound- of the cardinality rulerightBound- of the cardinality rule
-
AggregateAtom
public AggregateAtom(AggregateAtom other)
Copy-Constructor- Parameters:
other- another AggregateAtom
-
-
Method Detail
-
getLiterals
public java.util.SortedSet<ASPLiteral> getLiterals()
Description copied from class:ASPBodyElementReturns all literals in this element in form of a SortedSet. Literals are atoms or strict negations of atoms.- Specified by:
getLiteralsin classASPBodyElement- Returns:
- all the literals used in the rule element
-
getPredicates
public java.util.Set<Predicate> getPredicates()
Description copied from interface:SimpleLogicalFormulaProcesses the set of all predicates which appear in this formula- Specified by:
getPredicatesin interfaceSimpleLogicalFormula- Specified by:
getPredicatesin classASPElement- Returns:
- all predicates that appear in this formula
-
getAtoms
public java.util.Set<ASPAtom> getAtoms()
Description copied from interface:SimpleLogicalFormulaProcesses the set of all atoms which appear in this formula- Specified by:
getAtomsin interfaceSimpleLogicalFormula- Specified by:
getAtomsin classASPElement- Returns:
- The set of all atoms
-
substitute
public AggregateAtom substitute(Term<?> t, Term<?> v)
Description copied from interface:ComplexLogicalFormulaSubstitutes all occurrences of term "v" in this formula by term "t" and returns the new formula.- Specified by:
substitutein interfaceComplexLogicalFormula- Specified by:
substitutein classASPBodyElement- Parameters:
t- the term to be substituted.v- the term to substitute.- Returns:
- a formula where every occurrence of "v" is replaced by "t".
-
getSignature
public FolSignature getSignature()
Description copied from interface:FormulaReturns the signature of the language of this formula.- Specified by:
getSignaturein interfaceFormula- Specified by:
getSignaturein classASPElement- Returns:
- the signature of the language of this formula.
-
clone
public AggregateAtom clone()
Description copied from interface:SimpleLogicalFormulaCreates a deep copy of this formula- Specified by:
clonein interfaceComplexLogicalFormula- Specified by:
clonein interfaceSimpleLogicalFormula- Specified by:
clonein classASPElement- Returns:
- the cloned formula
-
isLiteral
public boolean isLiteral()
- Returns:
- true if the formula represents a literal in the language or false otherwise
-
getTerms
public java.util.Set<Term<?>> getTerms()
- Returns:
- a set containing all terms of this logical structure
-
getTerms
public <C extends Term<?>> java.util.Set<C> getTerms(java.lang.Class<C> cls)
Description copied from interface:LogicStructureProcesses the set containing all terms of type C. This method uses the equals method of the given Class and therefore does not add terms which are sub classes of type C to the set.- Type Parameters:
C- the type of terms- Parameters:
cls- The Class structure containing type information about the searched term- Returns:
- A set containing all terms of type C of this logical structure
-
getAggregateElements
public java.util.List<AggregateElement> getAggregateElements()
-
hasLeftRelation
public boolean hasLeftRelation()
Returns true if the aggregate has a left aggregate relation (meaning a term that the aggregate's resulting value will be compared to using a comparative operator).- Returns:
- true if aggregate has left aggregate relation
-
hasRightRelation
public boolean hasRightRelation()
Returns true if the aggregate has a right aggregate relation (meaning a term that the aggregate's resulting value will be compared to using a comparative operator).- Returns:
- true if aggregate has right aggregate relation
-
getFunction
public ASPOperator.AggregateFunction getFunction()
- Returns:
- the aggregate function
-
setFunction
public void setFunction(ASPOperator.AggregateFunction function)
Sets the aggregate function.- Parameters:
function- an aggregate function
-
getRightOperator
public ASPOperator.BinaryOperator getRightOperator()
Returns the operator of the right aggregate relation.- Returns:
- comparative operator
-
setRightOperator
public void setRightOperator(ASPOperator.BinaryOperator op)
Sets the operator of the right aggregate relation.- Parameters:
op- comparative operator
-
getRightGuard
public Term<?> getRightGuard()
- Returns:
- the right relation term (right guard).
-
setRightGuard
public void setRightGuard(Term<?> relationTerm)
Set the right relation term (right guard).- Parameters:
relationTerm- some term
-
setRight
public void setRight(Term<?> term, ASPOperator.BinaryOperator op)
Set the right relation term and operator.- Parameters:
term-op-
-
getLeftOperator
public ASPOperator.BinaryOperator getLeftOperator()
Returns the operator of the left aggregate relation.- Returns:
- comparative operator
-
setLeftOperator
public void setLeftOperator(ASPOperator.BinaryOperator op)
Sets the operator of the left aggregate relation.- Parameters:
op- comparative operator
-
getLeftGuard
public Term<?> getLeftGuard()
Get the left relation term (right guard).- Returns:
- Term
-
setLeftGuard
public void setLeftGuard(Term<?> relationTerm)
Set the left relation term (right guard).- Parameters:
relationTerm- some term
-
setLeft
public void setLeft(Term<?> term, ASPOperator.BinaryOperator op)
Set the left relation term and operator.- Parameters:
term-op-
-
toString
public java.lang.String toString()
- Overrides:
toStringin classjava.lang.Object
-
printToClingo
public java.lang.String printToClingo()
Description copied from class:ASPElementReturns a representation of this ASP element in clingo (potassco) syntax. See https://potassco.org/ for more information.- Overrides:
printToClingoin classASPElement- Returns:
- String representation in clingo syntax
-
-