本文整理汇总了C++中TBox::checkToldCycle方法的典型用法代码示例。如果您正苦于以下问题:C++ TBox::checkToldCycle方法的具体用法?C++ TBox::checkToldCycle怎么用?C++ TBox::checkToldCycle使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类TBox
的用法示例。
在下文中一共展示了TBox::checkToldCycle方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: absorbIntoConcept
bool
TAxiom :: absorbIntoConcept ( TBox& KB ) const
{
WorkSet Cons;
DLTree* bestConcept = NULL;
// finds all primitive concept names
for ( const_iterator p = begin(), p_end = end(); p != p_end; ++p )
if ( InAx::isNegPC(*p) ) // FIXME!! review this during implementation of Nominal Absorption
{
Stat::SAbsCAttempt();
Cons.push_back(*p);
if ( InAx::getConcept(*p)->isSystem() )
bestConcept = *p;
}
// if no concept names -- return;
if ( Cons.empty() )
return false;
Stat::SAbsCApply();
// FIXME!! as for now: just take the 1st concept name
if ( bestConcept == NULL )
bestConcept = Cons[0];
// normal concept absorption
TConcept* Concept = InAx::getConcept(bestConcept);
#ifdef RKG_DEBUG_ABSORPTION
std::cout << " C-Absorb GCI to concept " << Concept->getName();
if ( Cons.size() > 1 )
{
std::cout << " (other options are";
for ( WorkSet::iterator q = Cons.begin(), q_end = Cons.end(); q != q_end; ++q )
if ( *q != bestConcept )
std::cout << " " << InAx::getConcept(*q)->getName();
std::cout << ")";
}
#endif
// adds a new definition
Concept->addDesc(createAnAxiom(bestConcept));
Concept->removeSelfFromDescription();
// in case T [= (A or \neg B) and (B and \neg A) there appears a cycle A [= B [= A
// so remove potential cycle
// FIXME!! just because TConcept can't get rid of cycle by itself
KB.clearRelevanceInfo();
KB.checkToldCycle(Concept);
KB.clearRelevanceInfo();
return true;
}