本文整理汇总了C++中Enode::getExpParent方法的典型用法代码示例。如果您正苦于以下问题:C++ Enode::getExpParent方法的具体用法?C++ Enode::getExpParent怎么用?C++ Enode::getExpParent使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Enode
的用法示例。
在下文中一共展示了Enode::getExpParent方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: expRemoveExplanation
//
// Undoes the effect of expStoreExplanation
//
void Egraph::expRemoveExplanation( )
{
assert( exp_undo_stack.size( ) >= 2 );
Enode * x = exp_undo_stack.back( );
exp_undo_stack.pop_back( );
Enode * y = exp_undo_stack.back( );
exp_undo_stack.pop_back( );
assert( x );
assert( y );
assert( !x->isEnil( ) );
assert( !y->isEnil( ) );
// We observe that we don't need to undo the rerooting
// of the explanation trees, because it doesn't affect
// correctness. We just have to reroot y on itself
assert( x->getExpParent( ) == y || y->getExpParent( ) == x );
if ( x->getExpParent( ) == y )
{
x->setExpParent( NULL );
x->setExpReason( NULL );
}
else
{
y->setExpParent( NULL );
y->setExpReason( NULL );
}
}
示例2: expReRootOn
//
// Subroutine of explainStoreExplanation
// Re-root the tree containing x, in such a way that
// the new root is x itself
//
void Egraph::expReRootOn ( Enode * x )
{
Enode * p = x;
Enode * parent = p->getExpParent( );
Enode * reason = p->getExpReason( );
x->setExpParent( NULL );
x->setExpReason( NULL );
while( parent != NULL )
{
// Save grandparent
Enode * grandparent = parent->getExpParent( );
// Save reason
Enode * saved_reason = reason;
reason = parent->getExpReason( );
// Reverse edge & reason
parent->setExpParent( p );
parent->setExpReason( saved_reason );
#ifdef PEDANTIC_DEBUG
assert( checkExpTree( parent ) );
#endif
// Move the two pointers
p = parent;
parent = grandparent;
}
}
示例3: expExplainAlongPath
//
// Subroutine of explain
// A step of explanation for x and y
//
void Egraph::expExplainAlongPath ( Enode * x, Enode * y )
{
Enode * v = expHighestNode( x );
Enode * to = expHighestNode( y );
while ( v != to )
{
Enode * p = v->getExpParent( );
assert( p != NULL );
Enode * r = v->getExpReason( );
// If it is not a congruence edge
if ( r != NULL )
{
if ( !isDup1( r ) )
{
assert( r->isTerm( ) );
explanation.push_back( r );
storeDup1( r );
}
}
// Otherwise it is a congruence edge
// This means that the edge is linking nodes
// like (v)f(a1,...,an) (p)f(b1,...,bn), and that
// a1,...,an = b1,...bn. For each pair ai,bi
// we have therefore to compute the reasons
else
{
assert( v->getCar( ) == p->getCar( ) );
assert( v->getArity( ) == p->getArity( ) );
expEnqueueArguments( v, p );
}
#ifdef PRODUCE_PROOF
if ( config.produce_inter > 0
&& config.logic != QF_AX )
{
cgraph.addCNode( v );
cgraph.addCNode( p );
cgraph.addCEdge( v, p, r );
}
#endif
expUnion( v, p );
v = expHighestNode( p );
}
}