本文整理汇总了C++中TBox::makeNonPrimitive方法的典型用法代码示例。如果您正苦于以下问题:C++ TBox::makeNonPrimitive方法的具体用法?C++ TBox::makeNonPrimitive怎么用?C++ TBox::makeNonPrimitive使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类TBox
的用法示例。
在下文中一共展示了TBox::makeNonPrimitive方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: absorbIntoNegConcept
/// absorb into negation of a concept; @return true if absorption is performed
bool
TAxiom :: absorbIntoNegConcept ( TBox& KB ) const
{
WorkSet Cons;
TConcept* Concept;
const DLTree* bestConcept = NULL;
// finds all primitive negated concept names without description
for ( const_iterator p = begin(), p_end = end(); p != p_end; ++p )
if ( (*p)->Element().getToken() == NOT && isName((*p)->Left())
&& (Concept = InAx::getConcept((*p)->Left()))->isPrimitive()
&& !Concept->isSingleton() && Concept->Description == NULL )
{
Stat::SAbsNAttempt();
Cons.push_back(*p);
}
// if no concept names -- return;
if ( Cons.empty() )
return false;
Stat::SAbsNApply();
// FIXME!! as for now: just take the 1st concept name
if ( bestConcept == NULL )
bestConcept = Cons[0];
// normal concept absorption
Concept = InAx::getConcept(bestConcept->Left());
#ifdef RKG_DEBUG_ABSORPTION
std::cout << " N-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)->Left())->getName();
std::cout << ")";
}
#endif
// replace ~C [= D with C=~notC, notC [= D:
// make notC [= D
TConcept* nC = KB.getAuxConcept(createAnAxiom(bestConcept));
// define C = ~notC; C had an empty desc, so it's safe not to delete it
KB.makeNonPrimitive ( Concept, createSNFNot(KB.getTree(nC)) );
return true;
}
示例2: if
bool
TAxiom :: absorbIntoTop ( TBox& KB ) const
{
TConcept* C = NULL;
// check whether the axiom is Top [= C
for ( const_iterator p = begin(), p_end = end(); p != p_end; ++p )
if ( InAx::isBot(*p) ) // BOTTOMS are fine
continue;
else if ( InAx::isPosCN(*p) ) // CN found
{
if ( C != NULL ) // more than one concept
return false;
C = InAx::getConcept((*p)->Left());
if ( C->isSingleton() ) // doesn't work with nominals
return false;
}
else
return false;
if ( C == NULL )
return false;
// make an absorption
Stat::SAbsTApply();
DLTree* desc = KB.makeNonPrimitive ( C, createTop() );
#ifdef RKG_DEBUG_ABSORPTION
std::cout << " T-Absorb GCI to axiom";
if ( desc )
std::cout << "s *TOP* [=" << desc << " and";
std::cout << " " << C->getName() << " = *TOP*";
#endif
if ( desc )
KB.addSubsumeAxiom ( createTop(), desc );
return true;
}
示例3: if
bool
TAxiom :: absorbIntoTop ( TBox& KB ) const
{
TConcept* Cand = nullptr;
// check whether the axiom is Top [= C
for ( const auto& C: Disjuncts )
if ( InAx::isBot(C) ) // BOTTOMS are fine
continue;
else if ( InAx::isPosCN(C) ) // CN found
{
if ( Cand != nullptr ) // more than one concept
return false;
Cand = InAx::getConcept(C->Left());
if ( Cand->isSingleton() ) // doesn't work with nominals
return false;
}
else
return false;
if ( Cand == nullptr )
return false;
// make an absorption
Stat::SAbsTApply();
DLTree* desc = KB.makeNonPrimitive ( Cand, createTop() );
#ifdef RKG_DEBUG_ABSORPTION
std::cout << " T-Absorb GCI to axiom";
if ( desc )
std::cout << "s *TOP* [=" << desc << " and";
std::cout << " " << Cand->getName() << " = *TOP*";
#endif
if ( desc )
KB.addSubsumeAxiom ( createTop(), desc );
return true;
}