WikiDer > Разрешение SLD
Разрешение SLD (Селективный линейный определенный пункт резолюции) является основным правило вывода используется в логическое программирование. Это уточнение разрешающая способность, что одновременно звук и опровержение полный за Роговые оговорки.
Правило вывода SLD
Учитывая предложение о цели:
с выбранным буквальным , и входное определенное предложение:
чей положительный литерал (атом) объединяет с атомом выбранного литерала , Разрешение SLD порождает другое целевое предложение, в котором выбранный литерал заменяется отрицательными литералами входного предложения и объединяющей замены применяется:
В простейшем случае в логике высказываний атомы и идентичны, а объединяющая подстановка пусто. Однако в более общем случае объединяющая подстановка необходима, чтобы сделать два литерала идентичными.
Происхождение названия "SLD"
Название «разрешение SLD» было дано Маартеном ван Эмденом для неназванного правила вывода, введенного Роберт Ковальски.[1] Его название происходит от разрешения SL,[2] что является одновременно здравым и полным опровержением для неограниченной формы логики. «SLD» означает «резолюция SL с определенными пунктами».
И в SL, и в SLD буква L означает тот факт, что доказательство разрешения может быть ограничено линейной последовательностью предложений:
где "верхняя часть" является предложением ввода, а все остальные предложения резольвента, одним из родителей которой является предыдущий пункт . Доказательство является опровержением, если последнее предложение это пустое предложение.
В SLD все предложения в последовательности являются целевыми, а другой родительский пункт является входным. В разрешении SL другой родительский элемент является либо предложением ввода, либо предложением предка ранее в последовательности.
И в SL, и в SLD буква «S» означает тот факт, что единственный буквальный смысл, разрешенный в любом пункте - это тот, который однозначно выбирается правилом выбора или функцией выбора. В разрешении SL выбранный литерал ограничен тем, который был введен в предложение самым последним. В простейшем случае такая функция выбора "последним вошел - первым ушел" может быть определена порядком, в котором написаны литералы, как в Пролог. Однако функция выбора в разрешении SLD более общая, чем в разрешении SL и в Prolog. Ограничений на выбор литерала нет.
Вычислительная интерпретация разрешения SLD
В клаузальной логике опровержение SLD демонстрирует, что входной набор предложений неудовлетворителен. Однако в логическом программировании опровержение SLD также имеет вычислительную интерпретацию. Верхняя статья можно трактовать как отрицание конъюнкции подцелей . Вывод статьи из вывод с помощью обратное рассуждение, нового набора подцелей с использованием предложения ввода в качестве процедуры приведения к цели. Объединяющая подмена оба передают входные данные от выбранной подцели в тело процедуры и одновременно передают выходные данные от заголовка процедуры к оставшимся невыбранным подцелям. Пустое предложение - это просто пустой набор подцелей, который сигнализирует о том, что начальное соединение подцелей в верхнем предложении было решено.
Стратегии разрешения SLD
Разрешение SLD неявно определяет дерево поиска альтернативных вычислений, в которых предложение начальной цели связано с корнем дерева. Для каждого узла в дереве и для каждого определенного предложения в программе, положительный литерал которого объединяется с выбранным литералом в предложении цели, связанном с узлом, существует дочерний узел, связанный с предложением цели, полученным с помощью разрешения SLD.
Конечный узел, у которого нет дочерних узлов, является узлом успеха, если связанное с ним целевое предложение является пустым предложением. Это узел сбоя, если связанное с ним целевое предложение не пусто, но его выбранный литерал объединяется с положительным литералом предложения без ввода.
Разрешение SLD не является детерминированным в том смысле, что оно не определяет стратегию поиска для исследования дерева поиска. Prolog просматривает дерево сначала в глубину, по одной ветви за раз, используя отслеживание с возвратом при обнаружении узла сбоя. Поиск в глубину очень эффективно использует вычислительные ресурсы, но является неполным, если пространство поиска содержит бесконечные ветви и стратегия поиска ищет их, а не конечные ветви: вычисление не завершается. Другие стратегии поиска, в том числе в ширину, сначала лучшее и разветвленный поиск также возможен. Более того, поиск может выполняться последовательно, по одному узлу за раз, или параллельно, на многих узлах одновременно.
Разрешение SLD также недетерминировано в том смысле, о котором упоминалось ранее, что правило выбора не определяется правилом вывода, а определяется отдельной процедурой принятия решения, которая может быть чувствительной к динамике процесса выполнения программы.
Пространство поиска разрешения SLD - это дерево-или, в котором разные ветви представляют альтернативные вычисления. В случае программ пропозициональной логики SLD можно обобщить так, чтобы пространство поиска было и / или дерево, чьи узлы помечены одиночными литералами, представляющими подцели, а узлы соединяются либо соединением, либо дизъюнкцией. В общем случае, когда объединенные подцели имеют общие переменные, представление в виде дерева и / или является более сложным.
Пример
Учитывая логическую программу:
q: - p
п
и цель верхнего уровня:
q
пространство поиска состоит из одной ветви, в которой q
сводится к п
который сводится к пустому набору подцелей, сигнализирующему об успешном вычислении. В этом случае программа настолько проста, что функция выбора не играет никакой роли и не требует никакого поиска.
В клаузальной логике программа представлена набором предложений:
а цель верхнего уровня представлена предложением цели с одним отрицательным литералом:
Пространство поиска состоит из одного опровержения:
куда представляет пустое предложение.
Если в программу был добавлен следующий пункт:
д: - г
тогда в пространстве поиска будет дополнительная ветвь, листовой узел которой р
это отказавший узел. В Prolog, если бы это предложение было добавлено в начало исходной программы, то Prolog использовал бы порядок, в котором написаны предложения, для определения порядка, в котором исследуются ветви пространства поиска. Prolog сначала пробует эту новую ветвь, терпит неудачу, а затем возвращается, чтобы исследовать единственную ветвь исходной программы и добиться успеха.
Если оговорка
п: - р
были добавлены в программу, тогда в дереве поиска будет бесконечная ветвь. Если сначала попробовать это предложение, то Prolog войдет в бесконечный цикл и не найдет успешную ветвь.
SLDNF
SLDNF[3] является расширением разрешения SLD для решения отрицание как неудача. В SLDNF целевые предложения могут содержать отрицание как литералы отказа, скажем, в форме , которые можно выбрать, только если они не содержат переменных. Когда выбран такой литерал без переменных, субдоказательство (или субвычисление) пытается определить, существует ли опровержение SLDNF, начиная с соответствующего неэгрегированного литерала. как верхний пункт. Выбранная подцель считается успешным, если субдоказательство терпит неудачу, и неудачным, если субдоказательство успешно.
Смотрите также
Рекомендации
- ^ Роберт Ковальски Логика предикатов как язык программирования Памятка 70, факультет искусственного интеллекта, Эдинбургский университет. 1973 г. Также в материалах Конгресса ИФИП, Стокгольм, North Holland Publishing Co., 1974, стр. 569-574.
- ^ Роберт Ковальски и Дональд Кюнер, Линейное разрешение с функцией выбора Искусственный интеллект, Vol. 2, 1971, стр. 227-60.
- ^ Кшиштоф Апт и Маартен ван Эмден, Вклад в теорию логического программирования, Журнал Ассоциации вычислительной техники. Том 1982 - portal.acm.org
- Жан Галье, SLD-разрешение и логическое программирование глава 9 Логика для компьютерных наук: основы автоматического доказательства теорем, Онлайн-версия 2003 г. (бесплатная загрузка), первоначально опубликованная Wiley, 1986 г.
- Джон С. Шепердсон, SLDNF-разрешение с равенством, Journal of Automated Reasoning 8: 297-306, 1992; определяет семантику, относительно которой SLDNF-разрешение с равенством является правильным и полным
внешняя ссылка
- [1] Определение из бесплатного он-лайн словаря вычислительной техники