Как было показано в главе 1, экспертные системы состоят из трех компонентов:
- базы знаний, содержащей правила продукций;
- базы данных, которая отображает текущее состояние некоторой задачи;
- управляющей структуры (интерпретатора), решающей, какое из правил продукции надлежит применить следующим.
При нормальных условиях в иерархии руководства имеется множество подобных путей (Рисунок 4.1).
В определенных точках сталкиваемся с необходимостью выбора пути, для чего требуется подходящий метод, задаваемый управляющей структурой. Ясно, что любой основанный на логике подход обеспечит возможность сделать это, но один из очевидных способов решения подобной задачи сводится к тому, что сначала следует двигаться вдоль самой левой ветви дерева до тех пор, пока не будет, удовлетворен запрос или не будет достигнут конец ветви. В последнем случае нужно должны “отступить” в предыдущую точку ветвления и с помощью того же метода произвести проверку других ветвей. В результате, как это видно (Рисунок 4.1), путь обработки, соответствующий запросу “отчитывается (Фред, Петр)?” показан в виде пунктирной линии. Это называется поиском “сначала вглубь”. На этом же рисунке изображена и схема поиска “сначала вширь”. Обе стратегии рассмотрят все возможные варианты, что очень часто приводит к возникновению комбинаторного взрыва.
На глобальном уровне управления последовательностью применения правил можно выделить две стратегии поведения- применения правил в прямом и обратном порядке. Прямой порядок означает, что цепь рассуждений строится, отталкиваясь от известных фактов к гипотезам. Обратная цепочка означает, что рассуждения строятся, отталкиваясь от заданной цели к фактам, которые подтверждают эту цель.
Поиск "сначала вглубь"
Поиск "сначала вширь"
Рисунок 4.1 Обработка иерархии отношений