Просто типизированное лямбда-исчисление - Simply typed lambda calculus

В просто типизированное лямбда-исчисление (), форма теория типов, это печатная интерпретация из лямбда-исчисление только с одним конструктор типов (), который строит типы функций. Это канонический и простейший пример типизированного лямбда-исчисления. Просто типизированное лямбда-исчисление было первоначально введено Церковь Алонсо в 1940 году как попытка избежать парадоксального использования нетипизированное лямбда-исчисление, и он демонстрирует много желанных и интересных свойств.

Период, термин простой тип также используется для обозначения расширений просто типизированного лямбда-исчисления, таких как товары, побочные продукты или же натуральные числа (Система T ) или даже полный рекурсия (подобно PCF ). Напротив, системы, которые вводят полиморфные типы (например, Система F ) или же зависимые типы (словно Логическая структура ) не считаются просто набрал. Первые, кроме полной рекурсии, до сих пор считаются просто поскольку Церковные кодировки таких конструкций можно сделать только и подходящие переменные типа, а полиморфизм и зависимость - нет.

Синтаксис

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

Чтобы определить типы, мы начнем с фиксации набора базовые типы, . Иногда их называют атомные типы или же константы типа. С этим исправленным синтаксисом типов будет:

.

Например, , генерирует бесконечный набор типов, начиная с

Также фиксируем набор константы для базовых типов. Например, мы можем предположить, что базовый тип нац, а термин «константы» может быть натуральным числом. В исходной презентации Черч использовал только два базовых типа: для "типа предложений" и для «типа лиц». Тип не имеет констант, тогда как имеет одну постоянную члена. Часто исчисление только с одним базовым типом, обычно , Считается.

Синтаксис просто типизированного лямбда-исчисления по сути аналогичен самому лямбда-исчислению. Мы пишем чтобы обозначить, что переменная относится к типу . Таким образом, синтаксис термина в BNF:

куда - термальная постоянная.

То есть, ссылка на переменную, абстракции, заявление, и постоянный. Ссылка на переменную является граница если он находится внутри привязки абстракции . Срок закрыто если нет несвязанных переменных.

Сравните это с синтаксисом нетипизированного лямбда-исчисления:

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

Правила набора

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

В типизация отношения указывает, что это термин типа в контексте . В этом случае как говорят хорошо напечатанный (имеющий тип ). Экземпляры отношения типизации называются печатать суждения. Обоснованность заключения о типировании демонстрируется предоставлением печатание вывода, построенный с использованием правила набора текста (при этом посылки над линией позволяют сделать вывод под линией). Лямбда-исчисление с простой типизацией использует следующие правила:

(1) (2)
(3) (4)

Прописью,

  1. Если имеет тип в контексте мы знаем, что имеет тип .
  2. Терминные константы имеют соответствующие базовые типы.
  3. Если в определенном контексте с имеющий тип , имеет тип , то в том же контексте без , имеет тип .
  4. Если в определенном контексте имеет тип , и имеет тип , тогда имеет тип .

Примеры закрытых условий, т.е. термины, вводимые в пустом контексте, следующие:

  • Для любого типа , термин (тождественная функция / I-комбинатор),
  • Для типов , термин (K-комбинатор) и
  • Для типов , термин (S-комбинатор).

Это типизированные представления лямбда-исчисления основных комбинаторов комбинаторная логика.

Каждый тип присваивается заказ, номер . Для базовых типов ; для типов функций, . То есть порядок типа измеряет глубину самой левой стрелки. Следовательно:

Семантика

Внутренние и внешние интерпретации

Вообще говоря, есть два разных способа присвоения значения просто типизированному лямбда-исчислению, как и типизированным языкам в более общем смысле, иногда называемым внутренний против. внешний, или же Церковь -стиль против. Карри -стиль.[1]Внутренняя семантика / семантика в стиле Чёрча присваивает значение только хорошо типизированным терминам или, точнее, придает значение непосредственно типизированным производным. Это приводит к тому, что термины, различающиеся только аннотациями типов, тем не менее, могут иметь разные значения. Например, термин идентичности на целых числах и тождественном члене на логических значениях может означать разные вещи. (Классические предполагаемые интерпретации - это функция идентичности для целых чисел и функция идентичности для логических значений.) Напротив, внешняя семантика / стиль Карри присваивает значение терминам независимо от набора текста, поскольку они будут интерпретироваться на нетипизированном языке. С этой точки зрения и означают то же самое (т.е., то же самое, что и ).

Различие между внутренней и внешней семантикой иногда связано с наличием или отсутствием аннотаций в лямбда-абстракциях, но, строго говоря, такое использование неточно. Можно определить семантику в стиле Карри для аннотированных терминов, просто игнорируя типы (т.е., через стирание типа ), поскольку можно дать семантику в стиле Чёрча на неаннотированных терминах, когда типы могут быть выведены из контекста (т.е., через вывод типа ). Существенное различие между внутренним и внешним подходами состоит только в том, рассматриваются ли правила типизации как определение языка или как формализм для проверки свойств более примитивного базового языка. Большинство различных семантических интерпретаций, обсуждаемых ниже, можно рассматривать либо с точки зрения Черча, либо с точки зрения Карри.

Теория уравнений

Просто типизированное лямбда-исчисление имеет то же эквациональная теория βη-эквивалентности при нетипизированное лямбда-исчисление, но с учетом ограничений типа. Уравнение для бета-уменьшение

в контексте в любое время и , а уравнение для эта редукция

держится всякий раз, когда и не кажется свободным в .

Операционная семантика

Точно так же операционная семантика просто типизированного лямбда-исчисления можно исправить, как и для нетипизированного лямбда-исчисления, используя позвонить по имени, вызов по значению, или другой стратегии оценки. Что касается любого типизированного языка, безопасность типа является фундаментальным свойством всех этих оценочных стратегий. Кроме того, сильная нормализация свойство описано ниже подразумевает, что любая стратегия оценки завершится на всех просто набранных условиях.

Категориальная семантика

Просто типизированное лямбда-исчисление (с -эквивалентность) - внутренний язык из Декартовы закрытые категории (CCCs), как впервые заметил Ламбек. Для любого конкретного CCC основными типами соответствующего лямбда-исчисления являются просто объекты, а условия морфизмы. И наоборот, каждое просто типизированное лямбда-исчисление дает CCC, объектами которого являются типы, а морфизмы - классы эквивалентности терминов.

Чтобы прояснить соответствие, конструктор типов для Декартово произведение обычно добавляется к вышеуказанному. Чтобы сохранить категоричность декартова произведения, добавляют правила типа за спаривание, проекция, а единичный член. Учитывая два условия и , период, термин имеет тип . Точно так же, если у кого-то есть срок , то есть термины и где соответствуют проекциям декартова произведения. В единичный член, типа 1, записывается как и звучит как "ноль", это последний объект. Аналогичным образом расширяется эквациональная теория, так что

Последнее читается как "если t имеет тип 1, то он сводится к нулю".

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

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

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

Теоретико-доказательная семантика

Просто типизированное лямбда-исчисление тесно связано с импликационным фрагментом пропозиционального интуиционистская логика, т.е. минимальная логика, через Изоморфизм Карри – Ховарда: термины точно соответствуют доказательствам в естественный вычет, и жилые типы точно тавтологии минимальной логики.

Альтернативные синтаксисы

Представленное выше представление - не единственный способ определить синтаксис просто типизированного лямбда-исчисления. Одна из альтернатив - полностью удалить аннотации типов (чтобы синтаксис был идентичен нетипизированному лямбда-исчислению), при этом обеспечивая правильную типизацию терминов с помощью Вывод типа Хиндли-Милнера. Алгоритм вывода является завершающим, надежным и завершенным: всякий раз, когда термин является типизированным, алгоритм вычисляет его тип. Точнее, он вычисляет термин основной тип, так как часто неаннотированный термин (например, ) может иметь более одного типа (, и т. д., которые все являются экземплярами основного типа ).

Другое альтернативное представление просто типизированного лямбда-исчисления основано на двунаправленная проверка типов, который требует большего количества аннотаций типов, чем вывод Хиндли – Милнера, но его легче описать. В система типов делится на два приговора, представляющих оба проверка и синтез, написано и соответственно. В функциональном отношении три компонента , , и все входы на контрольное решение , тогда как обобщающее суждение только берет и в качестве входных данных, производя тип как выход. Эти суждения основаны на следующих правилах:

[1] [2]
[3] [4]
[5] [6]

Обратите внимание, что правила [1] - [4] почти идентичны правилам (1) - (4) выше, за исключением тщательного выбора проверочных или обобщающих суждений. Этот выбор можно объяснить так:

  1. Если находится в контексте, мы можем синтезировать тип за .
  2. Типы термических констант фиксированы и могут быть синтезированы.
  3. Чтобы проверить это имеет тип в некотором контексте мы расширяем контекст с помощью и проверьте это имеет тип .
  4. Если синтезирует тип (в некотором контексте), и проверяет тип (в том же контексте), то синтезирует тип .

Обратите внимание, что правила синтеза читаются сверху вниз, а правила проверки - снизу вверх. Обратите внимание, в частности, что мы делаем нет нужны какие-либо аннотации к лямбда-абстракции в правиле [3], потому что тип связанной переменной может быть выведен из типа, по которому мы проверяем функцию. Наконец, мы объясняем правила [5] и [6] следующим образом:

  1. Чтобы проверить это имеет тип , достаточно синтезировать тип .
  2. Если проверяет тип , то явно аннотированный член синтезирует .

Из-за того, что эти последние два правила сопряжены между синтезом и проверкой, легко увидеть, что любой хорошо типизированный, но не аннотированный термин может быть проверен в двунаправленной системе, если мы вставляем «достаточно» аннотаций типов. А на самом деле аннотации нужны только при β-редексах.

Общие наблюдения

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

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

Важные результаты

  • В 1967 году Тейт показал, что -восстановление сильно нормализующий. Как следствие -эквивалентность разрешимый. Статман показал в 1977 году, что проблема нормализации не элементарный рекурсивный, доказательство, которое позже было упрощено Майерсоном (1992). Доказательство чисто семантической нормализации (см. нормализация оценкой ) был дан Бергером и Швихтенбергом в 1991 году.
  • В объединение проблема для -эквивалентность неразрешима. В 1973 году Хуэ показал, что объединение третьего порядка неразрешимо, и это было улучшено Бакстером в 1978 году, а затем Гольдфарбом в 1981 году, показав, что объединение второго порядка уже неразрешимо.Доказательство того, что сопоставление более высокого порядка (унификация, где только один член содержит экзистенциальные переменные) разрешимо, было объявлено Колином Стирлингом в 2006 году, а полное доказательство было опубликовано в 2009 году.[2]
  • Мы можем кодировать натуральные числа по типу (Церковные цифры ). Швихтенберг показал в 1976 г., что в точно расширенный многочлены могут быть представлены как функции над числами Чёрча; это примерно полиномы, замкнутые под условным оператором.
  • А полная модель из задается путем интерпретации базовых типов как наборы и типы функций по теоретико-множественной функциональное пространство. Фридман показал в 1975 году, что эта интерпретация полный за -эквивалентность, если базовые типы интерпретируются бесконечными множествами. Статман показал в 1983 году, что -эквивалентность - это максимальная эквивалентность, которая типично двусмысленный, т.е. замкнутые относительно подстановок типов (Типичная теорема Статмана о неоднозначности). Следствием этого является то, что конечное свойство модели , т.е. конечных наборов достаточно, чтобы различать термины, не идентифицируемые -эквивалентность.
  • Плоткин ввел логические отношения в 1973 году для характеристики элементов модели, которые можно определить с помощью лямбда-терминов. В 1993 году Юнг и Тюрин показали, что общая форма логического отношения (логические отношения Крипке с разной степенью достоверности) в точности характеризует лямбда-определимость. Плоткин и Статман предположили, что разрешимо ли определимость данного элемента модели, порожденной из конечных множеств, с помощью лямбда-члена (Гипотеза Плоткина – Статмана). В 1993 году Лоадер показал, что это предположение неверно.

Примечания

  1. ^ Рейнольдс, Джон (1998). Теории языков программирования. Кембридж, Англия: Издательство Кембриджского университета.
  2. ^ Стирлинг, Колин (22 июля 2009 г.). «Разрешимость согласования высшего порядка». Логические методы в информатике. 5 (3): 1–52. arXiv:0907.3804. Дои:10.2168 / LMCS-5 (3: 2) 2009 г..

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

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