DDD
1.9.0.20240826145154
|
Public Member Functions | |
_VarCompVar (int v1, comparator c, int v2) | |
bool | skip_variable (int vr) const |
The skip_variable predicate indicates which variables are "don't care" with respect to this SHom. More... | |
const GHom::range_t | get_range () const |
The range returns the dual of skip_variable, default implem considers that all variables are affected by this homomorphism. More... | |
GDDD | phiOne () const |
Evaluation over terminal GDDD::one. More... | |
GHom | phi (int vr, int vl) const |
Evaluation over an arbitrary arc of a SDD. More... | |
GHom | compose (const GHom &other) const |
size_t | hash () const |
Hash key computation. More... | |
bool | is_selector () const |
The isSelector predicate indicates a homomorphism that only selects paths in the SDD (no modifications, no additions) Tagging with isSelector() allows to enable optimizations and makes the homomorphism eligible as "condition" in ITE construct. More... | |
void | print (std::ostream &os) const |
pretty print More... | |
bool | operator== (const StrongHom &s) const |
Comparator is pure virtual. Define a behavior in user homomorphisms. More... | |
_GHom * | clone () const |
bool | operator== (const _GHom &h) const |
Comparator for unicity table. More... | |
GDDD | eval (const GDDD &) const |
The evaluation mechanism of strong homomorphisms. More... | |
virtual GDDD | has_image (const GDDD &) const |
GDDD | has_image_skip (const GDDD &) const |
virtual GHom | invert (const GDDD &) const |
returns the predescessor homomorphism, using pot to determine variable domains More... | |
bool | operator< (const _GHom &h) const |
Ordering between _GHom. It is the chronological ordering of creation. More... | |
virtual void | mark () const |
For garbage collection. Used in first phase of garbage collection. More... | |
virtual GHom | negate () const |
returns a negation of a selector homomorphism h, such that h.negate() (d) = d - h(d) More... | |
Static Public Member Functions | |
static const _GHom * | get_concret (const GHom &ghom) |
Private Member Functions | |
GDDD | eval_skip (const GDDD &) const |
Private Attributes | |
int | var1 |
int | var2 |
comparator | c |
int | refCounter |
For garbage collection. More... | |
bool | marking |
For garbage collection. More... | |
bool | immediat |
For operation cache management. More... | |
size_t | creation_counter |
Counter of objects created (see constructors). More... | |
|
inline |
Referenced by clone().
|
inlinevirtual |
Implements _GHom.
References _VarCompVar().
Reimplemented from _GHom.
References c, _GHom::compose(), EQ, _GHom::get_concret(), LT, GDDD::null, var1, and var2.
The evaluation mechanism of strong homomorphisms.
Evaluation is defined as :
Let an SDD d= (var, Union_i (val_i, d_i) )
h (d) = Sum_i ( phi(var, val_i) (d_i) )
Implements _GHom.
References DED::add(), GDDD::begin(), GDDD::end(), GDDD::null, GDDD::one, StrongHom::phi(), StrongHom::phiOne(), GDDD::top, and GDDD::variable().
References GDDD::begin(), GDDD::end(), _GHom::eval(), GHom::id, GDDD::null, GDDD::one, _GHom::skip_variable(), GDDD::top, and GDDD::variable().
Referenced by GHom::eval().
References GHom::concret.
Referenced by Add::Add(), addCompositionParameter(), _VarCompState::compose(), compose(), And::eval(), Fixpoint::eval(), Fixpoint::has_image(), Inter::skip_variable(), NotCond::skip_variable(), Add::skip_variable(), Monotonic::skip_variable(), Compose::skip_variable(), RightConcat::skip_variable(), and Fixpoint::skip_variable().
|
inlinevirtual |
Reimplemented from _GHom.
References GDDD::begin(), GDDD::end(), GDDD::null, GDDD::one, StrongHom::phi(), StrongHom::phiOne(), GDDD::top, and GDDD::variable().
References GDDD::begin(), GDDD::end(), _GHom::has_image(), GHom::has_image(), GHom::id, GDDD::null, GDDD::one, _GHom::skip_variable(), GDDD::top, and GDDD::variable().
|
inlinevirtual |
Hash key computation.
It is essential for good hash table operation that the spread of the keys be as good as possible. Also, fast hash key computation is a good design goal. Note that bad hash functions will yield more collisions, thus equality comparisons which may be quite costly.
Implements _GHom.
returns the predescessor homomorphism, using pot to determine variable domains
Reimplemented in _incVar, _setVarConst, Fixpoint, Minus, And, Compose, Monotonic, Add, Inter, Mult, Apply2k, Constant, and Identity.
References _GHom::GHom, _GHom::is_selector(), GDDD::null, and _GHom::print().
Referenced by GHom::invert().
|
inlinevirtual |
|
inlinevirtualinherited |
For garbage collection. Used in first phase of garbage collection.
Reimplemented in MLHomAdapter, Fixpoint, Minus, RightConcat, LeftConcat, And, Compose, Monotonic, Add, NotCond, Inter, Mult, Apply2k, and Constant.
Referenced by GHom::mark().
|
virtualinherited |
returns a negation of a selector homomorphism h, such that h.negate() (d) = d - h(d)
Reimplemented in _VarCompState, And, Add, NotCond, Inter, Constant, and Identity.
References _GHom::GHom.
Referenced by GHom::negate().
|
inherited |
Ordering between _GHom. It is the chronological ordering of creation.
References _GHom::creation_counter.
|
virtualinherited |
Comparator for unicity table.
Users should not use this. The behavior is to check for type mismatch (and return false if that is the case) or call specialized comparators of derived subclasses otherwise.
Implements _GHom.
|
inlinevirtual |
|
inlinevirtual |
Evaluation over an arbitrary arc of a SDD.
var | the index of the variable labeling the node. |
val | the value labeling the arc. |
Implements StrongHom.
References c, _GHom::GHom, invertComp(), var1, var2, and varCompState().
|
inlinevirtual |
|
inlinevirtual |
pretty print
Reimplemented from StrongHom.
References c, GDDD::getvarName(), to_string(), var1, and var2.
|
inlinevirtual |
The skip_variable predicate indicates which variables are "don't care" with respect to this SHom.
This is defined as a StrongHom with : phi(var,val) { if ( skip_variable(var) ) return GShom( var, val, this ); else { real behavior } }
Reimplemented from _GHom.
|
private |
Referenced by compose(), hash(), operator==(), phi(), and print().
|
privateinherited |
Counter of objects created (see constructors).
This is used for the ordering between homomorphisms.
Referenced by _GHom::_GHom(), and _GHom::operator<().
|
mutableprivateinherited |
For operation cache management.
If immediat==true, eval is called without attempting a cache hit. Currently only the constant homomorphism has this attribute set to true.
Referenced by GHom::operator()().
|
mutableprivateinherited |
For garbage collection.
Used in the two phase garbage collection process. A Hom that is not marked after the first pass over the unicity table, will be sweeped in the second phase. Outside of garbage collection routine, marking should always bear the value false.
Referenced by GHom::garbage(), and GHom::mark().
|
mutableprivateinherited |
For garbage collection.
Counts the number of times a _GShom is referenced from the context of an Shom.
Referenced by Hom::Hom(), Hom::operator=(), GHom::refCounter(), and Hom::~Hom().
|
private |
Referenced by compose(), get_range(), hash(), operator==(), phi(), print(), and skip_variable().
|
private |
Referenced by compose(), get_range(), hash(), operator==(), phi(), print(), and skip_variable().