вызывается метод operator ()
, определенный в классе-потомке. Обратите внимание на определение оператора '||' (см. листинг 12.6). Этот оператор определен следующим образом.
template <class C> bool proposition<C>::operator||
(proposition &X)
{
return((*this)() || X());
}
Это определение позволяет использовать следующий код.
trip_announcement А;
performance_statement В;
if (А || В) {
// Какие-нибудь действия.
}
При вычис
bool trip_announcement::operator()(void) {
list<trip_announcement>::iterator I;
if(directTrip()){
return(true);
}
I = UniverseOfDiscourse.begin();
if(validTrip(I, Origin)){
return(true);
}
return(false);
}
При выполнении этого кода станет ясно, существует ли маршрут из заданного исходного пункта в некоторый пункт назнаначения. Например, предположим, что нас интересует переезд из Детройта в Колумбус, при этом область рассуждений содержит следующие данные:
Детройт - Толедо
Толедо - Колу
Тогда объект класса trip_announcement «доложит» о то
Детройт - Колу
Объект класса trip_announcement действительно проверит, существует ли прямой маршрут из Детройта в Колумбус. Если он существует, объект возвратит значение ИСТИНА. В противном случае он попытается найти обходной путь. Подобное поведение реализуется так.
if(directTrip()){
return(true);
}
I = UniverseOfDiscourse.begin();
if(validTrip(I,Origin)){
return(true);
}
«Самоопределением» истинности объект обязан оператору operator () класса trip_anouncement. Метод directTrip () довольно прост, и его работа заключается в последовательном просмотре области рассуждений на предмет существования следующего утверждения:
Детройт - Колу
Метод validTrip ()
, чтобы узнать, существует ли обходной путь, использует технологию поиска вглубь (Depth First Search— DFS). Определения методов validTrip ()
и directTrip ()
приведены в листинге 12.7.
// Листинг 12.7. Определения методов validTrip() и // directTrip()
bool trip_announcement::validTrip(list<trip_announcement>::iterator I, string TempOrigin)
{
if(I == UniverseOfDiscourse.end()){ if(Candidates.empty()){ TruthValue = false; return (false);
}
else{
trip_announcement Temp; Temp = Candidates.top(); I = find(UniverseOfDiscourse.begin(), UniverseOfDiscourse.end(),Temp); UniverseOfDiscourse.erase(I); Candidates.pop(); I = UniverseOfDiscourse.begin(); if(I != UniverseOfDiscourse.end()){ TempOrigin = Origin;
} else {
TruthValue = false; return(false);
}
}
>
if((*I).origin() == TempOrigin &&
(*I).destination() == Destination){ Candidates.push(*I); TruthValue = true; return(true);
}
if((*I).origin() == TempOrigin){ TempOrigin = (*I).destination(); Candidates.push(*I);
}
I++;
return(validTrip(I,TempOrigin));
bool trip_announcement: :directTrip(void) {
list<trip_announcement>::iterator I; I = find(UniverseOfDiscourse.begin(),
UniverseOfDiscourse.end(), *this); if(I == UniverseOfDiscourse.end()){
TruthValue = false;
return(false);
}
TruthValue = true; return(true);
В обоих методах validTrip ()
и directTrip ()
используется алгоритм find() из стандартной библиотеки С++. UniverseOfDiscourse — это контейнер, который содержит убеждения агента и подготовленные для него утверждения. Вспомните, что одним из первых действий, предпринимаемых агентом, является вызов метода updateBeliefs (), который заполняет контейнер UniverseOfDiscourse. Определение метода updateBeliefs () приведено в листинге 12.8.
// Листинг 12.8. Обновление убеждений