Программирование наборов ответов: различия между версиями

Материал из Википедии — свободной энциклопедии
Перейти к навигации Перейти к поиску
[отпатрулированная версия][непроверенная версия]
Содержимое удалено Содержимое добавлено
м Бот: добавление заголовков в сноски; исправление двойных сносок, см. ЧаВо
Reformat 1 URL (Wayback Medic 2.5)) #IABot (v2.0.9.5) (GreenC bot
 
(не показано 9 промежуточных версий 8 участников)
Строка 1: Строка 1:
{{Парадигмы программирования}}
{{Парадигмы программирования}}
'''Программирование наборов ответов''' ({{lang-en|Answer set programming, ASP}}) — форма [[Декларативное программирование|декларативного программирования]], ориентированная на сложные (в основном [[NP-полная задача|NP-трудные]]) задачи поиска, основывающееся на свойствах стабильной семантики [[Логическое программирование|логического программирования]]. Задача поиска сводится к вычислению устойчивой модели и наборов решателей ({{lang-en|answer set solvers}}) — программ для генерации устойчивых моделей, которые используются для поиска. Вычислительный процесс, включённый в конструкцию набора решателей, — это надстройка над [[DPLL]]-алгоритмом, который всегда конечен (в отличие от оценки запроса в [[Пролог (язык программирования)|Прологе]], которая может привести к бесконечному циклу).
'''Программирование наборов ответов''' ({{lang-en|Answer set programming, ASP}}) — форма [[Декларативное программирование|декларативного программирования]], ориентированная на сложные (в основном [[NP-полная задача|NP-трудные]]) задачи поиска, основывающееся на свойствах стабильной семантики [[Логическое программирование|логического программирования]]. Задача поиска вычисление устойчивой модели и наборов решателей ({{lang-en|answer set solvers}}) — программ для генерации устойчивых моделей, которые используются для поиска. Вычислительный процесс, включённый в конструкцию набора решателей, — это надстройка над [[DPLL]]-алгоритмом, который всегда конечен (в отличие от оценки запроса в [[Пролог (язык программирования)|Прологе]], которая может привести к бесконечному циклу).


В более общем смысле техника включает все приложения из наборов ответов для [[Представление знаний|представления знаний]]<ref name=":2">{{статья |ссылка=http://arxiv.org/pdf/cs/0312045 |заглавие=Weight constraints as nested expressions |издание=Theory and Practice of Logic Programming |том=5 |номер=1—2 |страницы=45—74 |doi=10.1017/S1471068403001923 |язык=und |автор=Ferraris, P.; Lifschitz, V. |месяц=1 |год=2005}} [http://www.cs.utexas.edu/users/vl/papers/weight.ps as Postscript]</ref><ref name=":1" /> и использует оценки запросов в стиле Prolog для решения проблем, возникающих в этих наборах.
В более общем смысле техника включает все приложения из наборов ответов для [[Представление знаний|представления знаний]]<ref name=":2">{{статья |ссылка=http://arxiv.org/pdf/cs/0312045 |заглавие=Weight constraints as nested expressions |издание=Theory and Practice of Logic Programming |том=5 |номер=1—2 |страницы=45—74 |doi=10.1017/S1471068403001923 |язык=und |автор=Ferraris, P.; Lifschitz, V. |месяц=1 |год=2005}} [http://www.cs.utexas.edu/users/vl/papers/weight.ps as Postscript] {{Wayback|url=http://www.cs.utexas.edu/users/vl/papers/weight.ps |date=20170922030842 }}</ref><ref name=":1" /> и использует оценки запросов в стиле Prolog для решения проблем, возникающих в этих наборах.


== История ==
== История ==
Метод [[Автоматическое планирование и диспетчеризация|планирования]], предложенный в 1993 году Димопулосом, Небелем и Кёлером, является ранним примером программирования набора ответов. Их подход основан на взаимосвязи между планами и стабильными моделями. Soininen и Niemelä применили то, что теперь известно как программирование на основе ответа, к проблеме конфигурации продукта. Использование решающих наборов ответов для поиска было идентифицировано как новая парадигма программирования Марека и Трущинского в статье, появившейся в 25-летней перспективе по парадигме логического программирования, опубликованной в 1999 году и в [Niemelä 1999] . ] Действительно, новая терминология «набора ответов» вместо «стабильной модели» была впервые предложена Лифшицем в статье, выходящей в том же ретроспективном объёме, что и статья Марека-Трущинского.
Метод [[Автоматическое планирование и диспетчеризация|планирования]], предложенный в 1993 году Димопулосом, Небелем и Кёлером, является ранним примером программирования набора ответов. Их подход основан на взаимосвязи между планами и стабильными моделями. Soininen и Niemelä применили то, что теперь известно как программирование на основе ответа, к проблеме конфигурации продукта. Использование решающих наборов ответов для поиска было идентифицировано как новая парадигма программирования Марека и Трущинского в статье, появившейся в 25-летней перспективе по парадигме логического программирования, опубликованной в 1999 году и в [Niemelä 1999]. Действительно, новая терминология «набора ответов» вместо «стабильной модели» была впервые предложена Лифшицем в статье, выходящей в том же ретроспективном объёме, что и статья Марека-Трущинского.


== AnsProlog ==
== AnsProlog ==
Lparse — программа, изначально была созданная как инструмент {{Нп2|Проблема заземления символов|заземления||Symbol grounding problem}} для решателя smodels. AnsProlog — язык, используемый Lparse, используется как в Lparse, так и в таких решателях, как assat, clasp, cmodels], gNt, nomore++ и pbmodels.
Lparse — программа, изначально была создана, как инструмент формирования базовых высказываний {{Нп2|Проблема заземления символов|заземления||Symbol grounding problem}} для вычисления логических высказываний smodels. AnsProlog — язык, используемый Lparse, используется как в Lparse, так и в таких решателях, как assat, clasp, cmodels], gNt, nomore++ и pbmodels.


Программа на AnsProlog составляется из правил вида:
Программа на AnsProlog составляется из правил вида:
Строка 16: Строка 16:
</source>
</source>


Символ <code>:-</code> («if») убирается, если <code><body></code> пуст; такие правила называются ''фактами''. Простейший вид правил Lparse это [[Семантика стойких моделей|правила с ограничениями]].
Символ <code>:-</code> («if») убирается, если <code><body></code> пуст; такие правила называются ''фактами''. Простейший вид правил Lparse это [[Семантика стойких моделей|правила с ограничениями]].


Ещё одной полезной конструкцией является ''выбор''. Например, правило:
Ещё одной полезной конструкцией является ''выбор''. Например, правило:
Строка 24: Строка 24:
</source>
</source>


означает: выбрать случайно, какой из атомов <math>p,q,r</math> включить в стабильную модель. В lparse-программе, которая содержит это правило и больше никаких других правил, имеет 8 стабильных моделей подмножеств <math>\{p,q,r\}</math>. Определение стабильных моделей было ограничено до программ с выбором правил<ref name=":1">{{книга |часть=Stable model semantics of weight constraint rules |заглавие=Logic Programming and Nonmonotonic Reasoning: 5th International Conference, LPNMR '99, El Paso, Texas, USA, December 2–4, 1999 Proceedings |ссылка часть=https://books.google.com/books?id=Abj-OpFeDjQC&pg=PA317 |год=2000 |издательство=Springer |isbn=978-3-540-66749-0 |страницы=317—331 |серия=Lecture notes in computer science: Lecture notes in artificial intelligence |том=1730 |язык=en |автор=Niemelä, I.; Simons, P.; Soinenen, T. |ответственный=Gelfond, Michael; Leone, Nicole; Pfeifer, Gerald}} [http://www.tcs.hut.fi/~ini/papers/nss-lpnmr99-www.ps.gz as Postscript]</ref>. Выбор правил также может использоваться для сокращения формул логики.
означает: выбрать случайно, какой из атомов <math>p,q,r</math> включить в стабильную модель. В lparse-программе, которая содержит это правило и больше никаких других правил, имеет 8 стабильных моделей подмножеств <math>\{p,q,r\}</math>. Определение стабильных моделей было ограничено до программ с выбором правил<ref name=":1">{{книга |часть=Stable model semantics of weight constraint rules |заглавие=Logic Programming and Nonmonotonic Reasoning: 5th International Conference, LPNMR '99, El Paso, Texas, USA, December 2–4, 1999 Proceedings |ссылка часть=https://books.google.com/books?id=Abj-OpFeDjQC&pg=PA317 |год=2000 |издательство=Springer |isbn=978-3-540-66749-0 |страницы=317—331 |серия=Lecture notes in computer science: Lecture notes in artificial intelligence |том=1730 |язык=en |автор=Niemelä, I.; Simons, P.; Soinenen, T. |ответственный=Gelfond, Michael; Leone, Nicole; Pfeifer, Gerald}} [http://www.tcs.hut.fi/~ini/papers/nss-lpnmr99-www.ps.gz as Postscript] {{Wayback|url=http://www.tcs.hut.fi/~ini/papers/nss-lpnmr99-www.ps.gz |date=20081015152410 }}</ref>. Выбор правил также может использоваться для сокращения формул логики.


Например, правило ''выбор'' можно рассматривать как сокращение для совокупности трех формул «[[Закон исключённого третьего|исключенного третьего]]»:
Например, правило ''выбор'' можно рассматривать как сокращение для совокупности трех формул «[[Закон исключённого третьего|исключенного третьего]]»:
Строка 106: Строка 106:


=== Раскраска графа ===
=== Раскраска графа ===
''n''-раскраска графа <math>G = \left\lang V, E\right\rang</math> — это функция <math>color: V\to\{1,\dots,n\}</math> такая, что <math>color(x)\neq color(y)</math> для каждой пары смежных вершин <math>(x,y)\in E</math>. Мы хотели бы использовать ASP чтобы найти <math>n</math>-покраску данного графа (или определить, что её не существует).
''n''-раскраска [[Граф (математика)|графа]] <math>G = \left\lang V, E\right\rang</math> — это функция <math>color: V\to\{1,\dots,n\}</math> такая, что <math>color(x)\neq color(y)</math> для каждой пары смежных вершин <math>(x,y)\in E</math>. Мы хотели бы использовать ASP, чтобы найти <math>n</math>-покраску данного графа (или определить, что её не существует).


Это можно сделать с помощью следующей программы Lparse:
Это можно сделать с помощью следующей программы Lparse:
Строка 114: Строка 114:
:- color(X,I), color(Y,I), e(X,Y), c(I).
:- color(X,I), color(Y,I), e(X,Y), c(I).
</source>
</source>
Первая строка определяет номера <math>1,\dots,n</math> цветов. В зависимости от выбора правил в строке 2, уникальный цвет <math>i</math> должен быть назначен для каждой вершины <math>x</math>. Ограничение в строке 3 запрещает назначать один и тот же цвет к вершине <math>x</math> и <math>y</math> если существует ребро, соединяющее их.
Первая строка определяет номера <math>1,\dots,n</math> цветов. В зависимости от выбора правил в строке 2, уникальный цвет <math>i</math> должен быть назначен для каждой вершины <math>x</math>. Ограничение в строке 3 запрещает назначать один и тот же цвет к вершине <math>x</math> и <math>y</math>, если существует ребро, соединяющее их.


Если совместить этот файл с определением <math>G</math> таким как:
Если совместить этот файл с определением <math>G</math>, таким как:
<source lang="prolog">
<source lang="prolog">
v(1..100). % 1,...,100 вершины
v(1..100). % 1,...,100 вершины
Строка 124: Строка 124:
и запустить smodels на нём, с числовым значением <math>n</math> указанным в командной строке, тогда атомы формы <math>color(\dots,\dots)</math>в исходных данных smodels будут представлять собой <math>n</math>-раскраску <math>G</math>.
и запустить smodels на нём, с числовым значением <math>n</math> указанным в командной строке, тогда атомы формы <math>color(\dots,\dots)</math>в исходных данных smodels будут представлять собой <math>n</math>-раскраску <math>G</math>.


Программа в этом примере иллюстрирует «generate-and-test» организацию, которая часто встречается в простых ASP-программах. Правило выбор описывает набор «потенциальных решений». Затем следует ограничение, которое исключает все возможные решения, которые не приемлемы. Однако, сам процесс поиска, который принимает smodels и другие наборы решателей не основаны [[Метод проб и ошибок|методе проб и ошибок]].
Программа в этом примере иллюстрирует «generate-and-test» организацию, которая часто встречается в простых ASP-программах. Правило выбор описывает набор «потенциальных решений». Затем следует ограничение, которое исключает все возможные решения, которые не приемлемы. Однако сам процесс поиска, который принимает smodels и другие наборы решателей не основаны [[Метод проб и ошибок|методе проб и ошибок]].


=== Задача о клике ===
=== Задача о клике ===
Строка 130: Строка 130:
n {in(X) : v(X)}.
n {in(X) : v(X)}.
:- in(X), in(Y), v(X), v(Y), X!=Y, not e(X,Y), not e(Y,X).
:- in(X), in(Y), v(X), v(Y), X!=Y, not e(X,Y), not e(Y,X).
</source>Это ещё один пример generate-and-test орнанизации. Выбор правил в строке 1 «создает» все наборы, состоящие из вершин <math>\geq n</math>. Ограничения в строке 2 «отсеивают» те наборы, которые не являются кликами.
</source>Это ещё один пример generate-and-test организации. Выбор правил в строке 1 «создает» все наборы, состоящие из вершин <math>\geq n</math>. Ограничения в строке 2 «отсеивают» те наборы, которые не являются кликами.


=== Гамильтонов цикл ===
=== Гамильтонов цикл ===
[[Гамильтонов цикл]] в [[Ориентированный граф|ориентированном графе]] — [[Цикл (теория графов)|цикл]], который проходит через каждую вершину графа ровно один раз. Следующая lparse-программа может быть использована для поиска гамильтонового цикла в заданном ориентированном графе, если он существует; предполагается, что 0 — это одна из вершин:
[[Гамильтонов цикл]] в [[Ориентированный граф|ориентированном графе]] — [[Цикл (теория графов)|цикл]], который проходит через каждую вершину графа ровно один раз. Следующая lparse-программа может быть использована для поиска гамильтонова цикла в заданном ориентированном графе, если он существует; предполагается, что 0 — это одна из вершин:
<source lang="prolog">
<source lang="prolog">
{in(X,Y)} :- e(X,Y).
{in(X,Y)} :- e(X,Y).
Строка 150: Строка 150:


=== Синтаксический анализ ===
=== Синтаксический анализ ===
Обработка естественного языка и синтаксический анализ могут быть сформулированы как проблема ASP<ref name=":3">{{Cite web |url=http://loqtek.com/?id=course_pars&sec=1 |title=Dependency parsing |accessdate=2018-04-06 |archiveurl=https://archive.is/20150415155632/http://loqtek.com/?id=course_pars&sec=1 |archivedate=2015-04-15 |deadlink=yes }}</ref>.
Обработка естественного языка и синтаксический анализ могут быть сформулированы как проблема ASP<ref name=":3">{{Cite web |url=http://loqtek.com/?id=course_pars&sec=1 |title=Dependency parsing |accessdate=2018-04-06 |archiveurl=https://archive.today/20150415155632/http://loqtek.com/?id=course_pars&sec=1 |archivedate=2015-04-15 |deadlink=yes }}</ref>.
Следующий код анализирует латинскую фразу {{lang-la2|Puella pulchra in villa linguam latinam discit}} — «красивая девушка учится латыни в деревне».
Следующий код анализирует латинскую фразу {{lang-la2|Puella pulchra in villa linguam latinam discit}} — «красивая девушка учится латыни в деревне».
Синтаксическое дерево выражено ''дуговыми предикатами'', которые означают зависимости между словами в предложении.
Синтаксическое дерево выражено ''дуговыми предикатами'', которые означают зависимости между словами в предложении.
Вычисленная структура это линейно упорядоченное дерево.
Вычисленная структура это линейно упорядоченное дерево.
<source lang="prolog">
<source lang="prolog">
% ********** input sentence **********
% ********** input sentence **********
Строка 186: Строка 186:


== Сравнение реализаций ==
== Сравнение реализаций ==
Ранние системы, такие как Smodels, использовали поиск с возвратом, чтобы найти решение. С развитием теории и практики в [[Задача выполнимости булевых формул|задачах выполнимости булевых формул]] (Boolean SAT solvers), увеличивалось количество ASP решателей, спроектированных на основе SAT-решателей включая ASSAT и Cmodels. Они превращали ASP формулу в SAT предложение, применяли SAT решатель, а затем превращали решение обратно в ASP формы. Более современные системы, такие как Clasp, используют гибридный подход, используя конфликтующие алгоритмы без полного преобразования в форму булевой логики. Эти подходы позволяют значительно улучшить производительность, часто на порядок качественно лучше по сравнению с предыдущими методами с возвращением.
Ранние системы, такие как Smodels, использовали поиск с возвратом, чтобы найти решение. С развитием теории и практики в [[Задача выполнимости булевых формул|задачах выполнимости булевых формул]] (Boolean SAT solvers) увеличивалось количество ASP-решателей, спроектированных на основе SAT-решателей включая ASSAT и Cmodels. Они превращали ASP-формулу в SAT-предложение, применяли SAT-решатель, а затем превращали решение обратно в ASP-формы. Более современные системы, такие как Clasp, используют гибридный подход, используя конфликтующие алгоритмы без полного преобразования в форму булевой логики. Эти подходы позволяют значительно улучшить производительность, часто на порядок качественно лучше по сравнению с предыдущими методами с возвращением.


Проект Potassco работает поверх многих низкоуровневых систем, в том числе clasp, систему обоснователей gringo, и других.
Проект Potassco работает поверх многих низкоуровневых систем, в том числе clasp, систему обоснователей gringo, и других.


Большинство систем поддерживают переменные, но не напрямую, а преобразовывая код с помощью систем вроде Lparse или gringo. Необходимость непосредственного обоснования может вызвать комбинаторный взрыв; таким образом, системы, которые выполняют обоснование «на лету» могут иметь преимущество.
Большинство систем поддерживают переменные, но не напрямую, а преобразовывая код с помощью систем вроде Lparse или gringo. Необходимость непосредственного обоснования может вызвать комбинаторный взрыв; таким образом, системы, которые выполняют обоснование «на лету», могут иметь преимущество.


{| class="wikitable"
{| class="wikitable"
Строка 207: Строка 207:
!
!
|-
|-
| {{rh}} class="table-rh" |ASPeRiX<ref>[http://www.info.univ-angers.fr/pub/claire/asperix/ ASPeRiX<!-- Заголовок добавлен ботом -->]</ref>
| {{rh}} class="table-rh" |ASPeRiX<ref>{{Cite web |url=http://www.info.univ-angers.fr/pub/claire/asperix/ |title=ASPeRiX<!-- Заголовок добавлен ботом --> |access-date=2018-04-06 |archive-date=2016-11-08 |archive-url=https://web.archive.org/web/20161108121331/http://www.info.univ-angers.fr/pub/claire/asperix/ |deadlink=no }}</ref>
|[[Linux]]
|[[Linux]]
|[[GPL]]
|[[GPL]]
Строка 217: Строка 217:
|обоснование «на лету»
|обоснование «на лету»
|-
|-
| {{rh}} class="table-rh" |ASSAT<ref>[https://web.archive.org/web/20110717180541/http://assat.cs.ust.hk/]</ref>
| {{rh}} class="table-rh" |ASSAT<ref>[https://web.archive.org/web/20110717180541/http://assat.cs.ust.hk/ >ASSAT: Answer Set by SAT solvers<!-- Заголовок добавлен ботом -->]</ref>
|[[Solaris]]
|[[Solaris]]
|Бесплатная
|Бесплатная
Строка 227: Строка 227:
|основан на SAT-решателе
|основан на SAT-решателе
|-
|-
| {{rh}} class="table-rh" |Clasp Answer Set Solver<ref>[http://www.cs.uni-potsdam.de/clasp/ clasp: an ASP solver<!-- Заголовок добавлен ботом -->]</ref>
| {{rh}} class="table-rh" |Clasp Answer Set Solver<ref>{{Cite web |url=http://www.cs.uni-potsdam.de/clasp/ |title=clasp: an ASP solver<!-- Заголовок добавлен ботом --> |access-date=2018-04-06 |archive-date=2018-11-16 |archive-url=https://web.archive.org/web/20181116062935/https://www.cs.uni-potsdam.de/clasp/ |deadlink=no }}</ref>
|[[Linux]], [[macOS]], [[Microsoft Windows|Windows]]
|[[Linux]], [[macOS]], [[Microsoft Windows|Windows]]
|[[GPL]]
|[[GPL]]
Строка 237: Строка 237:
|основан на SAT-решателе
|основан на SAT-решателе
|-
|-
| {{rh}} class="table-rh" |Cmodels<ref>[http://www.cs.utexas.edu/users/tag/cmodels/ CMODELS - Answer Set programming System<!-- Заголовок добавлен ботом -->]</ref>
| {{rh}} class="table-rh" |Cmodels<ref>{{Cite web |url=http://www.cs.utexas.edu/users/tag/cmodels/ |title=CMODELS Answer Set programming System<!-- Заголовок добавлен ботом --> |access-date=2018-04-06 |archive-date=2005-12-02 |archive-url=https://web.archive.org/web/20051202120554/http://www.cs.utexas.edu/users/tag/cmodels/ |deadlink=no }}</ref>
|[[Linux]], [[Solaris]]
|[[Linux]], [[Solaris]]
|[[GPL]]
|[[GPL]]
Строка 248: Строка 248:
|-
|-
| {{rh}} class="table-rh" |[[DLV]]
| {{rh}} class="table-rh" |[[DLV]]
|[[Linux]], [[macOS]], [[Microsoft Windows|Windows]]<ref name="dlvsystem.com">{{cite web|url=http://www.dlvsystem.com|title=DLV System company page|publisher=DLVSYSTEM s.r.l.|accessdate=2011-11-16}}</ref>
|[[Linux]], [[macOS]], [[Microsoft Windows|Windows]]<ref name="dlvsystem.com">{{cite web|url=http://www.dlvsystem.com|title=DLV System company page|publisher=DLVSYSTEM s.r.l.|accessdate=2011-11-16|archive-date=2012-01-02|archive-url=https://web.archive.org/web/20120102234623/http://www.dlvsystem.com/|deadlink=no}}</ref>
|Бесплатная для академического и некоммерческого использования
|Бесплатная для академического и некоммерческого использования
|{{yes}}
|{{yes}}
Строка 255: Строка 255:
|{{no}}s
|{{no}}s
|{{yes}}
|{{yes}}
|не Lparse совместимый
|не Lparse-совместимый
|-
|-
| {{rh}} class="table-rh" |DLV-Complex<ref>[http://www.mat.unical.it/dlv-complex/ dlv-complex - dlv-complex<!-- Заголовок добавлен ботом -->]</ref>
| {{rh}} class="table-rh" |DLV-Complex<ref>{{Cite web |url=http://www.mat.unical.it/dlv-complex/ |title=dlv-complex dlv-complex<!-- Заголовок добавлен ботом --> |access-date=2018-04-06 |archive-date=2017-07-01 |archive-url=https://web.archive.org/web/20170701052243/https://www.mat.unical.it/dlv-complex/ |deadlink=no }}</ref>
|[[Linux]], [[macOS]], [[Microsoft Windows|Windows]]
|[[Linux]], [[macOS]], [[Microsoft Windows|Windows]]
|[[GPL]]
|[[GPL]]
Строка 267: Строка 267:
|основан на [[DLV]] — несовместимый c Lparse
|основан на [[DLV]] — несовместимый c Lparse
|-
|-
| {{rh}} class="table-rh" |GnT<ref>[http://www.tcs.hut.fi/Software/gnt/ TCS - Software - lpeq<!-- Заголовок добавлен ботом -->]</ref>
| {{rh}} class="table-rh" |GnT<ref>{{Cite web |url=http://www.tcs.hut.fi/Software/gnt/ |title=TCS Software lpeq<!-- Заголовок добавлен ботом --> |access-date=2018-04-06 |archive-date=2017-12-25 |archive-url=https://web.archive.org/web/20171225040233/http://www.tcs.hut.fi/Software/gnt/ |deadlink=no }}</ref>
|[[Linux]]
|[[Linux]]
|[[GPL]]
|[[GPL]]
Строка 277: Строка 277:
|основан на smodels
|основан на smodels
|-
|-
| {{rh}} class="table-rh" |nomore++<ref>[http://www.cs.uni-potsdam.de/nomore/ nomore: a Solver for Logic Programs<!-- Заголовок добавлен ботом -->]</ref>
| {{rh}} class="table-rh" |nomore++<ref>{{Cite web |url=http://www.cs.uni-potsdam.de/nomore/ |title=nomore: a Solver for Logic Programs<!-- Заголовок добавлен ботом --> |access-date=2018-04-06 |archive-date=2019-02-04 |archive-url=https://web.archive.org/web/20190204231436/https://www.cs.uni-potsdam.de/nomore/ |deadlink=no }}</ref>
|[[Linux]]
|[[Linux]]
|[[GPL]]
|[[GPL]]
Строка 287: Строка 287:
|комбинированные
|комбинированные
|-
|-
| {{rh}} class="table-rh" |Platypus<ref>[http://www.cs.uni-potsdam.de/platypus/ platypus: a Platform for Distributed Answer Set Programming<!-- Заголовок добавлен ботом -->]</ref>
| {{rh}} class="table-rh" |Platypus<ref>{{Cite web |url=http://www.cs.uni-potsdam.de/platypus/ |title=platypus: a Platform for Distributed Answer Set Programming<!-- Заголовок добавлен ботом --> |access-date=2018-04-06 |archive-date=2018-04-08 |archive-url=https://web.archive.org/web/20180408010154/https://www.cs.uni-potsdam.de/platypus/ |deadlink=no }}</ref>
|[[Linux]], [[Solaris]], [[Microsoft Windows|Windows]]
|[[Linux]], [[Solaris]], [[Microsoft Windows|Windows]]
|[[GPL]]
|[[GPL]]
Строка 297: Строка 297:
|распределённый
|распределённый
|-
|-
| {{rh}} class="table-rh" |Pbmodels<ref>http://www.cs.uky.edu/ai/pbmodels/</ref>
| {{rh}} class="table-rh" |Pbmodels<ref>{{Cite web |url=http://www.cs.uky.edu/ai/pbmodels/ |title=Источник |access-date=2018-04-06 |archive-date=2017-03-07 |archive-url=https://web.archive.org/web/20170307132728/http://www.cs.uky.edu/ai/pbmodels/ |deadlink=no }}</ref>
|[[Linux]]
|[[Linux]]
|?
|?
Строка 307: Строка 307:
|основан на псевдобулевском решателе
|основан на псевдобулевском решателе
|-
|-
| {{rh}} class="table-rh" |Smodels<ref>[http://www.tcs.hut.fi/Software/smodels/ Computing the Stable Model Semantics<!-- Заголовок добавлен ботом -->]</ref>
| {{rh}} class="table-rh" |Smodels<ref>{{Cite web |url=http://www.tcs.hut.fi/Software/smodels/ |title=Computing the Stable Model Semantics<!-- Заголовок добавлен ботом --> |access-date=2018-04-06 |archive-date=2018-03-24 |archive-url=https://web.archive.org/web/20180324134717/http://www.tcs.hut.fi/Software/smodels/ |deadlink=no }}</ref>
|[[Linux]], [[macOS]], [[Microsoft Windows|Windows]]
|[[Linux]], [[macOS]], [[Microsoft Windows|Windows]]
|[[GPL]]
|[[GPL]]
Строка 317: Строка 317:
|
|
|-
|-
| {{rh}} class="table-rh" |Smodels-cc<ref>[http://www.nku.edu/~wardj1/Research/smodels_cc.html Smodels_cc<!-- Заголовок добавлен ботом -->]</ref>
| {{rh}} class="table-rh" |Smodels-cc<ref>{{Cite web |url=http://www.nku.edu/~wardj1/Research/smodels_cc.html |title=Smodels_cc<!-- Заголовок добавлен ботом --> |access-date=2018-04-06 |archive-date=2015-11-15 |archive-url=https://web.archive.org/web/20151115171208/http://www.nku.edu/%7Ewardj1/Research/smodels_cc.html |deadlink=no }}</ref>
|[[Linux]]
|[[Linux]]
|?
|?
Строка 327: Строка 327:
|основан на SAT-решателе
|основан на SAT-решателе
|-
|-
| {{rh}} class="table-rh" |Sup<ref>http://www.cs.utexas.edu/users/tag/sup/</ref>
| {{rh}} class="table-rh" |Sup<ref>{{Cite web |url=http://www.cs.utexas.edu/users/tag/sup/ |title=SUP - Answer Set programming System<!-- Заголовок добавлен ботом --> |access-date=2018-04-06 |archive-date=2018-03-30 |archive-url=https://web.archive.org/web/20180330223539/http://www.cs.utexas.edu/users/tag/sup/ |deadlink=no }}</ref>
|[[Linux]]
|[[Linux]]
|?
|?
Строка 351: Строка 351:
* [http://potassco.sourceforge.net/clingo.html Clingo in the Browser]
* [http://potassco.sourceforge.net/clingo.html Clingo in the Browser]
* [https://potassco.org/clingo/ Clingo]
* [https://potassco.org/clingo/ Clingo]
*Беляев С.А., Родионов С.В. Программирование наборов ответов: учебно-методическое пособие. СПб.: Изд-во СПбГЭТУ «ЛЭТИ», 2020. 31 с. ISBN 978-5-7629-2660-7
{{rq|style|checktranslate|grammar}}
{{rq|style|checktranslate}}
{{внешние ссылки}}
{{внешние ссылки}}



Текущая версия от 20:29, 20 сентября 2023

Парадигмы программирования

Программирование наборов ответов (англ. Answer set programming, ASP) — форма декларативного программирования, ориентированная на сложные (в основном NP-трудные) задачи поиска, основывающееся на свойствах стабильной семантики логического программирования. Задача поиска — вычисление устойчивой модели и наборов решателей (англ. answer set solvers) — программ для генерации устойчивых моделей, которые используются для поиска. Вычислительный процесс, включённый в конструкцию набора решателей, — это надстройка над DPLL-алгоритмом, который всегда конечен (в отличие от оценки запроса в Прологе, которая может привести к бесконечному циклу).

В более общем смысле техника включает все приложения из наборов ответов для представления знаний[1][2] и использует оценки запросов в стиле Prolog для решения проблем, возникающих в этих наборах.

Метод планирования, предложенный в 1993 году Димопулосом, Небелем и Кёлером, является ранним примером программирования набора ответов. Их подход основан на взаимосвязи между планами и стабильными моделями. Soininen и Niemelä применили то, что теперь известно как программирование на основе ответа, к проблеме конфигурации продукта. Использование решающих наборов ответов для поиска было идентифицировано как новая парадигма программирования Марека и Трущинского в статье, появившейся в 25-летней перспективе по парадигме логического программирования, опубликованной в 1999 году и в [Niemelä 1999]. Действительно, новая терминология «набора ответов» вместо «стабильной модели» была впервые предложена Лифшицем в статье, выходящей в том же ретроспективном объёме, что и статья Марека-Трущинского.

Lparse — программа, изначально была создана, как инструмент формирования базовых высказываний заземления (англ. Symbol grounding problem) для вычисления логических высказываний smodels. AnsProlog — язык, используемый Lparse, используется как в Lparse, так и в таких решателях, как assat, clasp, cmodels], gNt, nomore++ и pbmodels.

Программа на AnsProlog составляется из правил вида:

<head> :- <body> .

Символ :- («if») убирается, если <body> пуст; такие правила называются фактами. Простейший вид правил Lparse — это правила с ограничениями.

Ещё одной полезной конструкцией является выбор. Например, правило:

{p,q,r}.

означает: выбрать случайно, какой из атомов включить в стабильную модель. В lparse-программе, которая содержит это правило и больше никаких других правил, имеет 8 стабильных моделей подмножеств . Определение стабильных моделей было ограничено до программ с выбором правил[2]. Выбор правил также может использоваться для сокращения формул логики.

Например, правило выбор можно рассматривать как сокращение для совокупности трех формул «исключенного третьего»:

Язык lparse позволяет нам писать «ограничения» правил выбора, такие как

1{p,q,r}2.

Это правило говорит: выбрать минимум один из атомом, но не более двух. Правило можно быть представлено в виде логической формулы:

Границы множества также могут быть использованы в качестве ограничения, например:

:- 2{p,q,r}.

Добавление этого ограничения в программу Lparse устраняет устойчивые модели, которые содержат менее двух атомов. Правило можно быть представлено в виде логической формулы:

.

Переменные (в верхнем регистре, как и в языке Prolog), используются в Lparse для укорачивания коллекций правил, Например, Lparse программа:

p(a). p(b). p(c).
q(X) :- p(X), X!=a.

имеет то же значение, что и:

p(a). p(b). p(c).
q(b). q(c).

Программа:

p(a). p(b). p(c).
{q(X):-p(X)}2.

Это укороченная версия:

p(a). p(b). p(c).
{q(a),q(b),q(c)}2.

Диапазон имеет вид:

<Predicate>(start..end)

где начало и конец — это константные арифметические значения. Диапазон — условное сокращение, которое используется в основном для обозначения числовых значений групповым способом.

Например факт:

a(1..3).

Это укороченная версия:

a(1). a(2). a(3).

Диапазоны также могут быть использованы в правилах со следующей семантикой:

p(X):q(X)

Если расширение q є {q(a1); q(a2); … ; q(aN)}, то вышеуказанное выражение семантически эквивалентно записи : p(a1), p(a2), … , p(aN).

Например:

q(1..2).
a :- 1 {p(X):q(X)}.

Это укороченная версия:

q(1). q(2).
a :- 1 {p(1), p(2)}.

Генерация устойчивых моделей

[править | править код]

Для нахождения устойчивой модели в Lparse-программе, которая хранится в файле ${filename} используется команда

% lparse ${filename} | smodels

Параметр 0 заставляет smodels найти все устойчивые модели программы. Например, если файл test содержит правила:

1{p,q,r}2.
s :- not p.

тогда команда выдаст:

% lparse test | smodels 0
Answer: 1
Stable Model: q p 
Answer: 2
Stable Model: p 
Answer: 3
Stable Model: r p 
Answer: 4
Stable Model: q s 
Answer: 5
Stable Model: r s 
Answer: 6
Stable Model: r q s

Примеры программ ASP

[править | править код]

Раскраска графа

[править | править код]

n-раскраска графа  — это функция такая, что для каждой пары смежных вершин . Мы хотели бы использовать ASP, чтобы найти -покраску данного графа (или определить, что её не существует).

Это можно сделать с помощью следующей программы Lparse:

c(1..n).                                           
1 {color(X,I) : c(I)} 1 :- v(X).             
:- color(X,I), color(Y,I), e(X,Y), c(I).

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

Если совместить этот файл с определением , таким как:

v(1..100). % 1,...,100 вершины
e(1,55). % существует ребро между 1 и 55
. . .

и запустить smodels на нём, с числовым значением указанным в командной строке, тогда атомы формы в исходных данных smodels будут представлять собой -раскраску .

Программа в этом примере иллюстрирует «generate-and-test» организацию, которая часто встречается в простых ASP-программах. Правило выбор описывает набор «потенциальных решений». Затем следует ограничение, которое исключает все возможные решения, которые не приемлемы. Однако сам процесс поиска, который принимает smodels и другие наборы решателей не основаны методе проб и ошибок.

Задача о клике

[править | править код]

Кликой в графе называют набор попарно смежных вершин. Следующая lparse-программа находит клику размера в данном графе, или определяет, что она не существует:

n {in(X) : v(X)}.
:- in(X), in(Y), v(X), v(Y), X!=Y, not e(X,Y), not e(Y,X).

Это ещё один пример generate-and-test организации. Выбор правил в строке 1 «создает» все наборы, состоящие из вершин . Ограничения в строке 2 «отсеивают» те наборы, которые не являются кликами.

Гамильтонов цикл

[править | править код]

Гамильтонов цикл в ориентированном графецикл, который проходит через каждую вершину графа ровно один раз. Следующая lparse-программа может быть использована для поиска гамильтонова цикла в заданном ориентированном графе, если он существует; предполагается, что 0 — это одна из вершин:

{in(X,Y)} :- e(X,Y).

:- 2 {in(X,Y) : e(X,Y)}, v(X).
:- 2 {in(X,Y) : e(X,Y)}, v(Y).

r(X) :- in(0,X), v(X).
r(Y) :- r(X), in(X,Y), e(X,Y).

:- not r(X), v(X).

Правило выбора в строке 1 «создаёт» все подмножества набора рёбер. Три ограничения «отсеивают» те подмножества, которые не являются гамильтоновыми циклами. Последний из них использует вспомогательный предикат достижимый из 0»), чтобы запретить вершины, которые не удовлетворяют этому условию. Этот предикат определяется рекурсивно в строках 4 и 5.

Синтаксический анализ

[править | править код]

Обработка естественного языка и синтаксический анализ могут быть сформулированы как проблема ASP[3]. Следующий код анализирует латинскую фразу Puella pulchra in villa linguam latinam discit — «красивая девушка учится латыни в деревне». Синтаксическое дерево выражено дуговыми предикатами, которые означают зависимости между словами в предложении. Вычисленная структура — это линейно упорядоченное дерево.

% ********** input sentence **********
word(1, puella). word(2, pulchra). word(3, in). word(4, villa). word(5, linguam). word(6, latinam). word(7, discit).
% ********** lexicon **********
1{ node(X, attr(pulcher, a, fem, nom, sg));
   node(X, attr(pulcher, a, fem, nom, sg)) }1 :- word(X, pulchra).
node(X, attr(latinus, a, fem, acc, sg)) :- word(X, latinam).
1{ node(X, attr(puella, n, fem, nom, sg));
   node(X, attr(puella, n, fem, abl, sg)) }1 :- word(X, puella).
1{ node(X, attr(villa, n, fem, nom, sg));
   node(X, attr(villa, n, fem, abl, sg)) }1 :- word(X, villa).
node(X, attr(linguam, n, fem, acc, sg)) :- word(X, linguam).
node(X, attr(discere, v, pres, 3, sg)) :- word(X, discit).
node(X, attr(in, p)) :- word(X, in).
% ********** syntactic rules **********
0{ arc(X, Y, subj) }1 :- node(X, attr(_, v, _, 3, sg)), node(Y, attr(_, n, _, nom, sg)).
0{ arc(X, Y, dobj) }1 :- node(X, attr(_, v, _, 3, sg)), node(Y, attr(_, n, _, acc, sg)).
0{ arc(X, Y, attr) }1 :- node(X, attr(_, n, Gender, Case, Number)), node(Y, attr(_, a, Gender, Case, Number)).
0{ arc(X, Y, prep) }1 :- node(X, attr(_, p)), node(Y, attr(_, n, _, abl, _)), X < Y.
0{ arc(X, Y, adv) }1 :- node(X, attr(_, v, _, _, _)), node(Y, attr(_, p)), not leaf(Y).
% ********** guaranteeing the treeness of the graph **********
1{ root(X):node(X, _) }1.
:- arc(X, Z, _), arc(Y, Z, _), X != Y.
:- arc(X, Y, L1), arc(X, Y, L2), L1 != L2.
path(X, Y) :- arc(X, Y, _).
path(X, Z) :- arc(X, Y, _), path(Y, Z).
:- path(X, X).
:- root(X), node(Y, _), X != Y, not path(X, Y).
leaf(X) :- node(X, _), not arc(X, _, _).

Сравнение реализаций

[править | править код]

Ранние системы, такие как Smodels, использовали поиск с возвратом, чтобы найти решение. С развитием теории и практики в задачах выполнимости булевых формул (Boolean SAT solvers) увеличивалось количество ASP-решателей, спроектированных на основе SAT-решателей включая ASSAT и Cmodels. Они превращали ASP-формулу в SAT-предложение, применяли SAT-решатель, а затем превращали решение обратно в ASP-формы. Более современные системы, такие как Clasp, используют гибридный подход, используя конфликтующие алгоритмы без полного преобразования в форму булевой логики. Эти подходы позволяют значительно улучшить производительность, часто на порядок качественно лучше по сравнению с предыдущими методами с возвращением.

Проект Potassco работает поверх многих низкоуровневых систем, в том числе clasp, систему обоснователей gringo, и других.

Большинство систем поддерживают переменные, но не напрямую, а преобразовывая код с помощью систем вроде Lparse или gringo. Необходимость непосредственного обоснования может вызвать комбинаторный взрыв; таким образом, системы, которые выполняют обоснование «на лету», могут иметь преимущество.

Платформа Особенности Механика
Название Операционная система Лицензия Переменные Функциональные символы Явные наборы Явные списки Правила выбора
ASPeRiX[4] Linux GPL Да Нет обоснование «на лету»
ASSAT[5] Solaris Бесплатная основан на SAT-решателе
Clasp Answer Set Solver[6] Linux, macOS, Windows GPL Да Да Нет Нет Да основан на SAT-решателе
Cmodels[7] Linux, Solaris GPL Требует обоснования Да основан на SAT-решателе
DLV Linux, macOS, Windows[8] Бесплатная для академического и некоммерческого использования Да Да Нет Нетs Да не Lparse-совместимый
DLV-Complex[9] Linux, macOS, Windows GPL Да Да Да Да основан на DLV — несовместимый c Lparse
GnT[10] Linux GPL Требует обоснования Да основан на smodels
nomore++[11] Linux GPL комбинированные
Platypus[12] Linux, Solaris, Windows GPL распределённый
Pbmodels[13] Linux ? основан на псевдобулевском решателе
Smodels[14] Linux, macOS, Windows GPL Требует обоснования Нет Нет Нет Нет
Smodels-cc[15] Linux ? Требует обоснования основан на SAT-решателе
Sup[16] Linux ? основан на SAT-решателе

Примечания

[править | править код]
  1. Ferraris, P.; Lifschitz, V. Weight constraints as nested expressions (неопр.) // Theory and Practice of Logic Programming. — 2005. — January (т. 5, № 1—2). — С. 45—74. — doi:10.1017/S1471068403001923. as Postscript Архивная копия от 22 сентября 2017 на Wayback Machine
  2. 1 2 Niemelä, I.; Simons, P.; Soinenen, T. Stable model semantics of weight constraint rules // Logic Programming and Nonmonotonic Reasoning: 5th International Conference, LPNMR '99, El Paso, Texas, USA, December 2–4, 1999 Proceedings (англ.) / Gelfond, Michael; Leone, Nicole; Pfeifer, Gerald. — Springer, 2000. — Vol. 1730. — P. 317—331. — (Lecture notes in computer science: Lecture notes in artificial intelligence). — ISBN 978-3-540-66749-0. as Postscript Архивная копия от 15 октября 2008 на Wayback Machine
  3. Dependency parsing. Дата обращения: 6 апреля 2018. Архивировано из оригинала 15 апреля 2015 года.
  4. ASPeRiX. Дата обращения: 6 апреля 2018. Архивировано 8 ноября 2016 года.
  5. >ASSAT: Answer Set by SAT solvers
  6. clasp: an ASP solver. Дата обращения: 6 апреля 2018. Архивировано 16 ноября 2018 года.
  7. CMODELS — Answer Set programming System. Дата обращения: 6 апреля 2018. Архивировано 2 декабря 2005 года.
  8. DLV System company page. DLVSYSTEM s.r.l.. Дата обращения: 16 ноября 2011. Архивировано 2 января 2012 года.
  9. dlv-complex — dlv-complex. Дата обращения: 6 апреля 2018. Архивировано 1 июля 2017 года.
  10. TCS — Software — lpeq. Дата обращения: 6 апреля 2018. Архивировано 25 декабря 2017 года.
  11. nomore: a Solver for Logic Programs. Дата обращения: 6 апреля 2018. Архивировано 4 февраля 2019 года.
  12. platypus: a Platform for Distributed Answer Set Programming. Дата обращения: 6 апреля 2018. Архивировано 8 апреля 2018 года.
  13. Источник. Дата обращения: 6 апреля 2018. Архивировано 7 марта 2017 года.
  14. Computing the Stable Model Semantics. Дата обращения: 6 апреля 2018. Архивировано 24 марта 2018 года.
  15. Smodels_cc. Дата обращения: 6 апреля 2018. Архивировано 15 ноября 2015 года.
  16. SUP - Answer Set programming System. Дата обращения: 6 апреля 2018. Архивировано 30 марта 2018 года.