Многосортная логика - Many-sorted logic

Многосортная логика может формально отражать наше намерение не рассматривать Вселенную как однородный сбор предметов, но чтобы раздел это похоже на типы в типичное программирование. И функциональный, и напористый "части речи "на языке логики отражают это типизированное разбиение вселенной даже на уровне синтаксиса: подстановка и передача аргументов могут выполняться только соответственно, с соблюдением" сортов ".

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

В область дискурса любой структура этой сигнатуры затем фрагментируется на непересекающиеся подмножества, по одному для каждого сорта.

Пример

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

Алгебраизация

Алгебраизация многосортной логики объясняется в статье Калейро и Гонсалвес,[1] который обобщает абстрактная алгебраическая логика к многосортному делу, но также может использоваться в качестве вводного материала.

Логика сортировки по порядку

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

,
,
,
,
,
,

и так далее.

Где бы термин какой-то требуется, срок любой подвид может быть поставлен вместо (Принцип подстановки Лискова ). Например, предполагая объявление функции , и постоянное объявление , период, термин совершенно верно и имеет вид . Чтобы предоставить информацию о том, что мать собаки, в свою очередь, является собакой, другое заявление может быть выдан; это называется перегрузка функции, похожий на перегрузка в языках программирования.

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

Чтобы включить логику с сортировкой по порядку в автоматическое средство доказательства теорем на основе предложений, соответствующий упорядоченное объединение необходим алгоритм, требующий для любых двух объявленных сортов их пересечение быть объявлено тоже: если и переменные вида и соответственно уравнение есть решение , куда .

Обобщенная логика Smolka с сортировкой по порядку, позволяющая параметрический полиморфизм.[3][4]В его структуре объявления подсортировки распространяются на выражения сложных типов. В качестве примера программирования параметрическая сортировка может быть объявлен (с параметр типа, как в Шаблон C ++ ), и из объявления подсортировки Соотношение выводится автоматически, что означает, что каждый список целых чисел также является списком чисел с плавающей запятой.

Обобщенная логика Шмидта-Шаусса с сортировкой по порядку для объявления терминов.[5]В качестве примера, предполагая объявления подсортировки и , объявление термина, например позволяет объявить свойство целочисленного сложения, которое не может быть выражено обычной перегрузкой.

Смотрите также

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

  1. ^ Карлос Калейро, Рикардо Гонсалвеш (2006). «Об алгебраизации многомерных логик». Proc. 18 инт. конф. о последних тенденциях в методах алгебраического развития (WADT) (PDF). Springer. С. 21–36. ISBN  978-3-540-71997-7.
  2. ^ Вальтер, Кристоф (1985). "Механическое решение парового катка Шуберта с помощью многоуровневого разрешения" (PDF). Артиф. Intell. 26 (2): 217–224. Дои:10.1016/0004-3702(85)90029-3.
  3. ^ Смолка, Герт (ноябрь 1988 г.). «Логическое программирование с полиморфно упорядоченными типами». Int. Практикум по алгебраическому и логическому программированию. LNCS. 343. Springer. С. 53–70.
  4. ^ Смолка, Герт (май 1989 г.), Логическое программирование над типами, отсортированными по полиморфному порядку, Univ. Кайзерслаутерн, Германия
  5. ^ Шмидт-Шаус, Манфред (апрель 1988 г.). Вычислительные аспекты упорядоченной логики с объявлениями термов. LNAI. 395. Springer.

Ранние работы по многосортной логике включают:

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