24.4.
Решение практических проблем
В главах с
10 по 15 мы познакомили вас с идеей, которая состоит в том, что существует несколько
обобщенных задач, которые в том или ином виде решаются в большинстве экспертных
систем. В частности, мы показали, чем отличаются задачи классификации от задач
конструирования, и что для своего решения эти задачи требуют применения совершенно
разных стратегий поиска.
При решении задач
классификации основной акцент делается на отыскании приемлемого, но, возможно,
приближенного соответствия между данными и решениями на некотором уровне абстракции.
Нужно учесть все имеющиеся свидетельства, объединить их каким-то образом,
а затем уточнить и ранжировать решения-кандидаты. В таких задачах пространство
решений, как правило, известно заранее, и представленные в нем категории могут
быть перенумерованы. Для работы с таким пространством вполне подходят методы
исчерпывающего поиска, которые используют наличие определенности для упорядочения
и отсечения путей поиска. Для работы с пространствами поиска большого объема,
которые не удается разбить на несколько относительно независимых подпространств,
приходится использовать более сложные методы, настроенные на определенную
форму организации пространства гипотез (например, иерархическую и причинную).
Суть задачи конструирования
состоит в построении некоторого сложного объекта, который должен удовлетворять
заданным ограничениям. Естественно, что при этом пространство решений оказывается
очень большим. Обычно не удается проследить все возможные пути на пространстве
решений в поиске оптимального, чаще всего отыскивается одно из приемлемых
решений, удовлетворяющих ограничениям. Ограничения могут влиять друг на друга,
и в такой ситуации для разрешения конфликтов нужно использовать знания о предметной
области. Наиболее общей для решения задач конструирования оказалась стратегия
предложение и пересмотр. Суть ее состоит в том, что частичные решения
расширяются до тех пор, пока не будут нарушены заданные ограничения, а затем
такое нарушение устраняется с помощью эвристик.
Несмотря на
то, что в большинстве случаев можно считать, что типичной задачей классификации
является диагностирование, а задачей конструирования — планирование, соответствие
между реальными приложениями и обобщенными задачами носит более сложный характер.
Вы имели возможность
убедиться, что такие программы диагностирования, как INTERNIST, фактически
используют методику решения задачи конструирования. Элементами решения являются
отказы, которые объединяются в составную гипотезу. Таким образом, оказывается,
что нет никакого смысла заранее нумеровать узлы пространства решений, поскольку
пациент может страдать десятью и более заболеваниями. Более того, в общем
виде проблема отыскания "наилучшего" объяснения имеющемуся набору
симптомов относится к классу необозримых. Без использования мощного механизма
концентрации внимания программы на определенном участке пространства не удается
отыскать даже приблизительное решение проблемы. Поэтому для решения подобных
задач дифференциального диагностирования используются средства, типичные для
задач конструирования.
Ряд программ, например
R1/XCON, обладает знаниями, достаточными для того, чтобы решить задачу конструирования
без использования рекурсии предположений и возврата назад. В рамках стратегии
нисходящего уточнения, которая предполагает разбиение задачи построения конфигурации
вычислительной системы на ряд практически независимых подзадач, система R1
иногда переключается на восходящую методику логического вывода. На примере
системы планирования ONCOCIN мы показали, что для решения проблемы планирования
могут иногда использоваться стратегии, характерные для задач эвристической
классификации. Благодаря тому, что в этой системе применяется довольно жестко
формализованное представление протоколов лечения онкозаболеваний, появилась
возможность выбирать подходящую заготовку плана лечения из библиотеки, а затем
адаптировать ее к конкретному случаю.
Но как бы
там ни было, разграничение задач классификации и конструирования оказалось исключительно
полезным, поскольку помогло автоматизировать процесс приобретения знаний. Было
также показано, что функциональные возможности программных средств извлечения
знаний могут быть существенно расширены, если такие средства будут включать
в свой состав декларативную модель предметной области и некоторые знания, касающиеся
решаемой задачи, в частности — как будут использованы в приложении получаемые
знания. Хотя разработка систем извлечения знаний с ограничением ролей, таких
как MORE и RIME, еще не вышла из стадии лабораторных экспериментов, они ознаменовали
собой появление новой мощной методологии построения баз знаний. В ее основу
положена концепция "извлечение знаний также должно базироваться на знаниях".
Первые полученные результаты дают основание надеяться, что на основе этой методологии
будут созданы эффективные средства, которые позволят устранить одно из основных
"узких" мест в практике проектирования экспертных систем. Автоматический
анализ целостности базы знаний и компиляция их в форму выполняемых модулей также
в значительной мере упрощается при использовании модели предметной области и
информации о принципах решения проблем, используемых в проектируемом приложении.