| 
 | ||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||
java.lang.Objectrwth.i2.ltlrv.formula.base.AbstractFormula
rwth.i2.ltlrv.afastate.base.AbstractAFAState
rwth.i2.ltlrv.afastate.base.NullaryAFAState
rwth.i2.ltlrv.afastate.impl.Proposition
public class Proposition
Proposition - Implements a proposition. A proposition may hold a list of bindings, which map formal parameters represented by Strings to actual objects. Two propositions are equal if their label is equal and their bindings are equal as well. This means, that each formal must be bound to the same object, not just to equal objects. References to objects have to be provided by maps emplyoing weak references.
WeakReference| Nested Class Summary | 
|---|
| Nested classes/interfaces inherited from interface rwth.i2.ltlrv.afastate.interfaze.IAFAState | 
|---|
| IAFAState.ValidationException, IAFAState.VariableKind | 
| Field Summary | |
|---|---|
| protected  WeakValuesMap<String,Object> | bindingsBindings of formal parameters for this proposition. | 
| protected  int | bindingsSizeCopy of size of the bindings map. | 
| protected  Collection<IIfClosure> | ifClosuresList of if-closures that have to be satisfied in order to match. | 
| protected  String | labelAn appropriate label for this proposition. | 
| protected  String[] | providesList of provided variables. | 
| protected  Set<String> | varsInIfClosure | 
| Fields inherited from class rwth.i2.ltlrv.formula.base.AbstractFormula | 
|---|
| factory | 
| Fields inherited from interface rwth.i2.ltlrv.afastate.interfaze.IProposition | 
|---|
| UNBOUND | 
| Constructor Summary | |
|---|---|
|   | Proposition(String label,
            String[] formals,
            IIfClosure[] ifClosures)Constructs a new proposition with the given label and free bindings for the given formals. | 
|   | Proposition(String label,
            WeakValuesMap<String,Object> bindings)Deprecated. | 
| private  | Proposition(String label,
            WeakValuesMap<String,Object> bindings,
            String[] provides,
            Collection<IIfClosure> ifClosures)Constructs a new proposition with the given label and bindings of formals to actual objects. | 
| Method Summary | |
|---|---|
| private  boolean | allIfClosuresSatisfied()Returns trueif all if closures are currently satisfied. | 
|  void | doTransition(Set<String> context,
             PropositionSet currentProps,
             WeakValuesMap<String,Object> currentBinding,
             Set<Set<IAFAState>> result)Performs the actual transition based on the current context. | 
|  boolean | equals(Object oth)Clients should implement this method, since the implementation uses HashSets, which require a proper notion of equality. | 
| private  boolean | fullyBound()Returns trueif this proposition is fully bound. | 
|  WeakValuesMap<String,Object> | getBindings()Returns a copy of all bindings in this proposition. | 
|  int | hashCode() | 
|  boolean | isFinalStateInAFA()Returns trueif this formula represents a final
 state in the AFA. | 
|  boolean | matches(IProposition specializedProposition)Returns trueif this proposition matches the
 given specializedProposition. | 
|  void | providesNeg(Set<String> result)This returns the set of negatively provided variables at the current temporal levels. | 
|  void | providesPos(Set<String> result)This returns the set of positively provided variables at the current temporal levels. | 
|  void | requires(Set<String> result)This returns the set of required variables. This is the set of all variables which are free in propositions, meaning they occur in an if-pointcut but are not provided by the same pointcut at the same time. | 
|  IProposition | specializeBindings(WeakValuesMap<String,Object> specializedBindings)Returns a fresh copy of this subformula with bindings in propositions specialized by the bindings of propositions, which are passed in as argument. | 
|  String | symbol()Returns the symbol for this term constructor. | 
|  String | toString() | 
|  void | unboundVariablesAtCurrentJoinpoint(IAFAState.VariableKind variableKind,
                                   Set<String> result) | 
|  void | validate(Set<String> context)To be implemented by actual formulae as described in IAFAState.validate(). | 
| private  Set<String> | variableNamesInIfClosures()Returns the set of variables that are contained in if-closures (including those that are bound by this pointcut). | 
| private  boolean | wasGarbageCollected() | 
| Methods inherited from class rwth.i2.ltlrv.afastate.base.NullaryAFAState | 
|---|
| getInstance, negationNormalForm | 
| Methods inherited from class rwth.i2.ltlrv.afastate.base.AbstractAFAState | 
|---|
| provides, transition, updateContext, validate | 
| Methods inherited from class java.lang.Object | 
|---|
| clone, finalize, getClass, notify, notifyAll, wait, wait, wait | 
| Methods inherited from interface rwth.i2.ltlrv.afastate.interfaze.INullaryAFAState | 
|---|
| getInstance | 
| Methods inherited from interface rwth.i2.ltlrv.afastate.interfaze.IAFAState | 
|---|
| provides, transition, validate | 
| Methods inherited from interface rwth.i2.ltlrv.formula.interfaze.IFormula | 
|---|
| negationNormalForm | 
| Field Detail | 
|---|
protected final String label
protected WeakValuesMap<String,Object> bindings
protected final int bindingsSize
protected final Collection<IIfClosure> ifClosures
IIfClosureprotected final Set<String> varsInIfClosure
protected final String[] provides
| Constructor Detail | 
|---|
public Proposition(String label,
                   String[] formals,
                   IIfClosure[] ifClosures)
label - an appropriate label for this propositionformals - list of formals that may be bound during evaluationifClosures - if-closures which are to be evaluated at runtimeIIfClosure
@Deprecated
public Proposition(String label,
                              WeakValuesMap<String,Object> bindings)
Proposition(String, String[], IIfClosure[]) in combination
 with specializeBindings(WeakValuesMap) instead.
label - an appropriate label for this propositionbindings - a map mapping from formals represented as String to actual
 objects
private Proposition(String label,
                    WeakValuesMap<String,Object> bindings,
                    String[] provides,
                    Collection<IIfClosure> ifClosures)
specializeBindings(WeakValuesMap)
label - an appropriate label for this propositionbindings - a map mapping from formals represented as String to actualprovides - old provides set. This is needed, cause bindings may have changed.ifClosures - if-closures which are to be evaluated at runtime| Method Detail | 
|---|
public String toString()
toString in class NullaryAFAStatepublic boolean isFinalStateInAFA()
true if this formula represents a final
 state in the AFA. This is the case if the formula is either
 a Release subformula, TT, or a boolean combination of
 subformulae evaluating to true.
isFinalStateInAFA in interface IAFAStatetrue if this formula represents a final
 state in the AFAIRelease, 
ITTprivate Set<String> variableNamesInIfClosures()
public boolean matches(IProposition specializedProposition)
true if this proposition matches the
 given specializedProposition. This is the case when
 the labels are equal and specializedProposition is
 at least as special as this, meaning it holds
 the same formals and at least the formals bound in this
 are bound in specializedProposition.
matches in interface IPropositionspecializedProposition - a specialized proposition
true if this proposition matches the
 given specializedPropositionpublic boolean equals(Object oth)
equals in interface IPropositionequals in class ObjectObject.equals(java.lang.Object)public int hashCode()
hashCode in interface IPropositionhashCode in class NullaryAFAStateObject.hashCode()public WeakValuesMap<String,Object> getBindings()
getBindings in interface IProposition
public void doTransition(Set<String> context,
                         PropositionSet currentProps,
                         WeakValuesMap<String,Object> currentBinding,
                         Set<Set<IAFAState>> result)
doTransition in class AbstractAFAStatecontext - @see #transition(Set, PropositionSet, WeakValuesMap, Set)currentProps - @see #transition(Set, PropositionSet, WeakValuesMap, Set)currentBinding - @see #transition(Set, PropositionSet, WeakValuesMap, Set)result - @see #transition(Set, PropositionSet, WeakValuesMap, Set)IAFAState.transition(Set, PropositionSet, WeakValuesMap, Set), 
AbstractAFAState.transition(Set, PropositionSet, WeakValuesMap, Set), 
AbstractAFAState.updateContext(Set)private boolean wasGarbageCollected()
private boolean allIfClosuresSatisfied()
true if all if closures are currently satisfied.
 This implies that the proposition is fully bound.
true if all if closures are currently satisfiedprivate boolean fullyBound()
true if this proposition is fully bound.
true if for all b in bindings,
 b!=IProposition.UNBOUND
public void unboundVariablesAtCurrentJoinpoint(IAFAState.VariableKind variableKind,
                                               Set<String> result)
unboundVariablesAtCurrentJoinpoint in interface IAFAStateunboundVariablesAtCurrentJoinpoint in class NullaryAFAStatepublic IProposition specializeBindings(WeakValuesMap<String,Object> specializedBindings)
NullaryAFAState
specializeBindings in interface IAFAStatespecializeBindings in interface IPropositionspecializeBindings in class NullaryAFAStatespecializedBindings - Set of propositions holding actual bindings.
IAFAState.specializeBindings(WeakValuesMap)public void providesPos(Set<String> result)
NullaryAFAState
        providesPos( phi /\ psi ) = providesPos( phi ) join providesPos( psi )
        providesPos( phi \/ psi ) = providesPos( phi ) intersect providesPos( psi )
        providesPos( phi R psi ) =  providesPos( (psi /\ phi) \/ (psi /\ X(phi R psi)) )
                                 =  providesPos( psi )
        providesPos( phi U psi ) = providesPos( psi \/ (phi /\ X(phi U psi) )
                                 = providesPos( psi ) intersect providesPos( phi ) 
        providesPos( X phi )     = emptyset
        providesPos( !prop )     = emptyset
        providesPos( prop )      = provided variables of prop
     
providesPos in interface IAFAStateprovidesPos in class NullaryAFAStateresult - The result will be placed here.public void providesNeg(Set<String> result)
NullaryAFAState
        providesNeg( phi /\ psi ) = providesNeg( phi ) intersect providesNeg( psi )
        providesNeg( phi \/ psi ) = providesNeg( phi ) join providesNeg( psi )
        providesNeg( phi R psi ) =  providesNeg( psi ) intersect providesNeg( phi )
        providesNeg( phi U psi ) =  providesNeg( psi )
        providesNeg( X phi )     = emptyset
        providesNeg( !prop )     = provided variables of prop
        providesNeg( prop )      = emptyset
     
providesNeg in interface IAFAStateprovidesNeg in class NullaryAFAStateresult - The result will be placed here.public void requires(Set<String> result)
requires in interface IAFAStaterequires in class NullaryAFAStateresult - The result will be placed here.
public void validate(Set<String> context)
              throws IAFAState.ValidationException
IAFAState.validate().
validate in class NullaryAFAStatecontext - Here the context is passed in from the outer (earlier) temporal layers.
IAFAState.ValidationExceptionpublic String symbol()
symbol in interface IFormula| 
 | ||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||