Отрицание как неудача - Negation as failure

Отрицание как неудача (NAF, для краткости) является немонотонный правило вывода в логическое программирование, используется для получения (т.е. что предполагается, что не выполняется) из-за невозможности получить . Обратите внимание, что может отличаться от утверждения из логическое отрицание из , в зависимости от полнота алгоритма вывода и, следовательно, также и в системе формальной логики.

Отрицание как неудача было важной чертой логического программирования с первых дней существования обоих. Планировщик и Пролог. В Прологе это обычно реализуется с использованием внелогических конструкций Пролога.

Семантика планировщика

В Planner отрицание как сбой может быть реализовано следующим образом:

если (нет (Цель п)), тогда (утверждать ¬p)

который говорит, что если исчерпывающий поиск, чтобы доказать п терпит неудачу, затем утверждать ¬p.[1] Это утверждает, что предложение п будет считаться «неверным» при любой последующей обработке. Однако, поскольку Planner не основан на логической модели, логическая интерпретация предшествующего остается неясной.

Семантика пролога

В чистом Прологе литералы NAF вида может находиться в теле предложений и может использоваться для получения других литералов NAF. Например, учитывая только четыре пункта

NAF является производным , и .

Семантика завершения

Семантика NAF оставалась открытым вопросом до 1978 года, когда Кейт Кларк показал, что это правильно в отношении завершения логической программы, где, грубо говоря, «только» и интерпретируются как «если и только если», записываются как «если и только если» или".

Например, завершение четырех пунктов выше

Правило вывода NAF явно имитирует рассуждения с завершением, где обе стороны эквивалентности отрицаются, а отрицание в правой части распределяется вниз до атомарные формулы. Например, чтобы показать , NAF моделирует рассуждения с эквивалентностями

В непропозициональном случае завершение необходимо дополнить аксиомами равенства, чтобы формализовать предположение, что индивиды с разными именами различны. NAF моделирует это отказом от унификации. Например, учитывая только два пункта

т

NAF является производным .

Завершение программы

дополнен аксиомами уникальных имен и аксиомами закрытия домена.

Семантика завершения тесно связана как с ограничение и к предположение о закрытом мире.

Аутоэпистемическая семантика

Семантика завершения оправдывает интерпретацию результата вывода NAF как классического отрицания из . Однако в 1987 г. Майкл Гельфонд показал, что можно также интерпретировать буквально как " не может быть показано "," не известно "или" не верится ", как в аутоэпистемическая логика. Аутоэпистемическая интерпретация была развита Гельфондом и Лифшиц в 1988 году и является основой программирование набора ответов.

Семантика автоэпистемы чистой программы Пролога P с литералами NAF получается "расширением" P с помощью набора основных (без переменных) литералов NAF Δ, которые являются стабильный в том смысле, что

Δ = { | не следует из P ∪ Δ}

Другими словами, набор предположений Δ о том, что нельзя показать, является стабильный тогда и только тогда, когда Δ - это множество всех предложений, которые действительно не могут быть показаны из программы P, расширенной на Δ. Здесь, из-за простого синтаксиса программ на чистом Прологе, «подразумевается» можно очень просто понимать как выводимость с использованием только modus ponens и универсального создания экземпляров.

Программа может иметь ноль, одно или несколько стабильных расширений. Например,

не имеет стабильных расширений.

имеет ровно одно устойчивое разложение Δ = {}

имеет ровно два устойчивых разложения Δ1 = {} и Δ2 = {}.

Аутоэпистемическая интерпретация NAF может сочетаться с классическим отрицанием, как в расширенном логическом программировании и программирование набора ответов. Комбинируя два отрицания, можно выразить, например,

(предположение о замкнутом мире) и
( по умолчанию).

Сноски

  1. ^ Кларк, Кит (1978). Логика и базы данных (PDF). Springer-Verlag. С. 293–322 (Отрицание как неудача). Дои:10.1007/978-1-4684-3384-5_11.

Рекомендации

внешняя ссылка

  • Отчет из семинара W3C по языкам правил для взаимодействия. Включает примечания по NAF и SNAF (отрицание с ограничением как отказ).