|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object scale.common.Root scale.score.Note scale.score.expr.Expr scale.score.expr.BinaryExpr
public abstract class BinaryExpr
This class is the superclass of all binary operators.
$Id: BinaryExpr.java,v 1.63 2007-10-17 13:39:59 burrill Exp $
Copyright 2008 by the
Scale Compiler Group,
Department of Computer Science
University of Massachusetts,
Amherst MA. 01003, USA
All Rights Reserved.
Field Summary |
---|
Fields inherited from class scale.score.expr.Expr |
---|
fpReorder, SE_DOMAIN, SE_NONE, SE_OVERFLOW, SE_STATE |
Constructor Summary | |
---|---|
BinaryExpr(Type t,
Expr la,
Expr ra)
|
Method Summary | |
---|---|
void |
associativeSwapOperands()
See if the associative property of the expression can be used to make two constants the arguments of the same binary expression. |
boolean |
containsDeclaration(Declaration decl)
Return true if this expression contains a reference to the variable. |
boolean |
dependsOnDeclaration(Declaration decl)
Return true if this expression's value depends on the variable. |
boolean |
equivalent(Expr exp)
Return true if the expressions are equivalent. |
int |
executionCostEstimate()
Return a relative cost estimate for executing the expression. |
AliasAnnote |
getAliasAnnote()
Get the alias annotation associated with a Scribble operator. |
void |
getDeclList(java.util.AbstractCollection<Declaration> varList)
Add all declarations referenced in this expression to the Vector. |
void |
getExprList(Vector<Expr> expList)
Add all Expr instances in this expression to the Vector. |
Expr |
getLeftArg()
Return the left argument to the operator. |
void |
getLoadExprList(Vector<LoadExpr> expList)
Add all LoadExpr instances in this expression to the Vector. |
Expr |
getOperand(int position)
Return the nth operand. |
Expr[] |
getOperandArray()
Return an array of the operands to the expression. |
Expr |
getRightArg()
Return the right argument to the operator. |
boolean |
isAssociative()
Return true if the binary operation is associative: (a α b) α c ≡ a α (b α c). |
boolean |
isCommutative()
Return true if the binary operation is commutative: (a α b) ≡ (b &alpha a). |
boolean |
isLeftDistributive()
Return true if the binary operation α is left distributive over β: (a β b) α c ≡ (a α c) β (b α c). |
boolean |
isRightDistributive()
Return true if the binary operation α is right distributive over β: a α (b β c) ≡ (a α b) β (a α c). |
void |
loopClean()
Clean up any loop related information. |
int |
numOperands()
Return the number of operands to this expression. |
boolean |
optimizationCandidate()
Return true if the expression can be moved without problems. |
void |
pushOperands(Stack<Expr> wl)
Push all of the operands of this expression on the Stack. |
void |
recordRefs(Chord stmt,
References refs)
Record any variable references in this expression in the table of references. |
void |
removeRefs(Chord stmt,
References refs)
Remove any variable references in this expression from the table of references. |
void |
removeUseDef()
Remove any use - def links, may - use links, etc. |
boolean |
replaceDecl(Declaration oldDecl,
Declaration newDecl)
Replace all occurrances of a Declaration with another Declaration. |
void |
setLeftArg(Expr la)
Replace the left operand. |
Expr |
setOperand(Expr operand,
int position)
Set the nth operand of an expression. |
void |
setRightArg(Expr ra)
Replace the right operand. |
int |
sideEffects()
Return an indication of the side effects execution of this expression may cause. |
void |
swapOperands()
Swap the left and right arguments. |
void |
unlinkExpression()
If the node is no longer needed, sever its use-def link, etc. |
void |
validate()
Check this node for validity. |
Methods inherited from class scale.score.Note |
---|
getChord, getEssentialUse, setAnnotationLevel, setReportLevel, toString, visit |
Methods inherited from class scale.common.Root |
---|
addAnnotation, allAnnotations, allMatchingAnnotations, getAnnotation, getDisplayName, getDisplayString, getNodeCount, getNodeID, hasAnnotation, hasEqualAnnotation, hashCode, removeAnnotation, removeAnnotations, toStringAnnotations, toStringClass, trace, trace, trace |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, notify, notifyAll, wait, wait, wait |
Constructor Detail |
---|
public BinaryExpr(Type t, Expr la, Expr ra)
Method Detail |
---|
public boolean equivalent(Expr exp)
equivalent
in class Expr
public Expr setOperand(Expr operand, int position)
operand
must not be
null
.
setOperand
in class Expr
operand
- - the new operandposition
- - indicates which operand
public Expr getOperand(int position)
getOperand
in class Expr
position
- the index of the operandpublic Expr[] getOperandArray()
getOperandArray
in class Expr
public int numOperands()
numOperands
in class Expr
public final Expr getLeftArg()
public final Expr getRightArg()
public final void setLeftArg(Expr la)
la
argument may be null
.
la
- is the new left argumentpublic final void setRightArg(Expr ra)
ra
argument may be null
.
ra
- is the new right argumentpublic final void swapOperands()
public void associativeSwapOperands()
(x + c1) + c2 is changed to (c2 +
c1) + x
. This method should be called only by associative
binary expressions.
public boolean isCommutative()
public boolean isAssociative()
public boolean isLeftDistributive()
public boolean isRightDistributive()
public void loopClean()
loopClean
in class Expr
public void unlinkExpression()
unlinkExpression
in class Expr
public boolean containsDeclaration(Declaration decl)
containsDeclaration
in class Expr
LoadExpr.setUseOriginal(boolean)
public boolean dependsOnDeclaration(Declaration decl)
dependsOnDeclaration
in class Expr
LoadExpr.setUseOriginal(boolean)
public boolean optimizationCandidate()
optimizationCandidate
in class Expr
public AliasAnnote getAliasAnnote()
getAliasAnnote
in class Expr
public int executionCostEstimate()
executionCostEstimate
in class Note
public void getDeclList(java.util.AbstractCollection<Declaration> varList)
getDeclList
in class Expr
public void getLoadExprList(Vector<LoadExpr> expList)
getLoadExprList
in class Expr
public void getExprList(Vector<Expr> expList)
getExprList
in class Expr
public void pushOperands(Stack<Expr> wl)
pushOperands
in class Expr
public boolean replaceDecl(Declaration oldDecl, Declaration newDecl)
replaceDecl
in class Expr
public void removeUseDef()
removeUseDef
in class Expr
public void validate()
validate
in class Expr
public void recordRefs(Chord stmt, References refs)
recordRefs
in class Expr
public void removeRefs(Chord stmt, References refs)
removeRefs
in class Expr
public int sideEffects()
sideEffects
in class Expr
Expr.SE_NONE
|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |