Переписка Карри – Ховарда - Curry–Howard correspondence

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

Это обобщение синтаксического аналогия между системами формальной логики и вычислительными исчислениями, впервые обнаруженными американцами математик Хаскелл Карри и логик Уильям Элвин Ховард.[1] Это связь между логикой и вычислением, которую обычно приписывают Карри и Ховарду, хотя идея связана с оперативной интерпретацией интуиционистская логика дан в различных формулировках Л. Э. Дж. Брауэр, Аренд Хейтинг и Андрей Колмогоров (видеть Интерпретация Брауэра – Гейтинга – Колмогорова )[2] и Стивен Клини (видеть Реализуемость ). Отношения были расширены и теперь включают теория категорий как трехсторонний Переписка Карри – Ховарда – Ламбека.

Происхождение, масштаб и последствия

Начало Переписка Карри – Ховарда лежат в нескольких наблюдениях:

  1. В 1934 г. Карри отмечает, что типы комбинаторов можно рассматривать как схемы аксиом за интуиционистский импликационная логика.[3]
  2. В 1958 году он отмечает, что некий вид система доказательств, именуемой Системы дедукции в стиле Гильберта, совпадает на некотором фрагменте с типизированным фрагментом стандарта модель вычисления известный как комбинаторная логика.[4]
  3. В 1969 г. Говард замечает, что другой, более "высокий уровень" система доказательств, именуемой естественный вычет, можно напрямую интерпретировать в его интуиционистский версия как типизированный вариант модель вычисления известный как лямбда-исчисление.[5]

Другими словами, соответствие Карри – Ховарда - это наблюдение того, что два семейства, казалось бы, не связанных между собой формализмов, а именно, системы доказательств с одной стороны и модели вычислений с другой, на самом деле являются одним и тем же видом математических объектов.

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

Переписка стала отправной точкой большого спектра новых исследований после его открытия, что привело, в частности, к новому классу исследований. формальные системы разработан, чтобы действовать как система доказательств и как набранный функциональный язык программирования. Это включает в себя Мартин-Лёф с интуиционистская теория типов и Coquand с Расчет конструкций, два исчисления, в которых доказательства являются регулярными объектами дискурса и в которых можно формулировать свойства доказательств так же, как и в любой программе. Это направление исследований принято называть современным. теория типов.

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

Обратное направление - использовать программу для извлечения доказательства, учитывая его правильность - область исследований, тесно связанная с код подтверждения. Это возможно только в том случае, если язык программирования программа написана для очень богато типизированной системы: разработка таких систем типов отчасти была мотивирована желанием сделать соответствие Карри – Ховарда практически актуальным.

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

Теоретически можно ожидать, что соответствие Карри – Ховарда приведет к существенному объединение между математической логикой и фундаментальной информатикой:

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

Наоборот, комбинаторная логика и просто типизированное лямбда-исчисление не единственные модели вычислений, либо. Жирара линейная логика был разработан на основе тонкого анализа использования ресурсов в некоторых моделях лямбда-исчисления; есть ли типизированная версия Машина Тьюринга что будет вести себя как система доказательств? Типизированные языки ассемблера являются таким примером "низкоуровневых" моделей вычислений, несущих типы.

Из-за возможности написания непрерывных программ, Полный по Тьюрингу модели вычислений (например, языки с произвольными рекурсивные функции ) следует интерпретировать с осторожностью, поскольку наивное применение соответствия ведет к противоречивой логике. Наилучший способ работы с произвольными вычислениями с логической точки зрения все еще является активно обсуждаемым вопросом исследований, но один популярный подход основан на использовании монады для отделения доказуемо завершающегося кода от потенциально незавершенного кода (подход, который также обобщается на гораздо более богатые модели вычислений,[6] и сам связан с модальной логикой естественным расширением изоморфизма Карри – Ховарда[доб 1]). Более радикальный подход, за который выступает полное функциональное программирование, состоит в том, чтобы исключить неограниченную рекурсию (и отказаться от Полнота по Тьюрингу, хотя по-прежнему сохраняя высокую вычислительную сложность), используя более контролируемые Corecursion везде, где действительно желательно непрерывное поведение.

Общая формулировка

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

На уровне формул и типов соответствие говорит, что импликация ведет себя так же, как тип функции, соединение как тип «продукта» (это может называться кортеж, структура, список или какой-либо другой термин в зависимости от языка. ), дизъюнкция как тип суммы (этот тип можно назвать объединением), ложная формула как пустой тип и истинная формула как одноэлементный тип (единственным членом которого является нулевой объект). Кванторы соответствуют зависимый функциональное пространство или продукты (при необходимости). Это обобщено в следующей таблице:

Логическая сторонаСторона программирования
универсальная количественная оценкаобобщенный вид продукта (Π тип)
экзистенциальная количественная оценкаобобщенный тип суммы (Тип Σ)
значениетип функции
соединениеТип продукта
дизъюнкциятип суммы
истинная формулатип единицы
ложная формуланижний тип

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

Логическая сторонаСторона программирования
Система дедукции в стиле Гильбертасистема типов для комбинаторная логика
естественный вычетсистема типов для лямбда-исчисление

Между системой естественного вывода и лямбда-исчислением существуют следующие соответствия:

Логическая сторонаСторона программирования
гипотезысвободные переменные
устранение последствий (modus ponens)заявление
введение импликацииабстракция

Соответствующие системы

Системы дедукции в стиле Гильберта и комбинаторная логика

Вначале это было простое замечание из книги Карри и Фейса по комбинаторной логике 1958 года: простейшие типы для базовых комбинаторов K и S комбинаторная логика удивительно соответствовал соответствующему схемы аксиом α → (βα) и (α → (β → Γ)) → ((αβ) → (α → Γ)), используемые в Системы дедукции в стиле Гильберта. По этой причине эти схемы теперь часто называют аксиомами K и S. Приведены примеры программ, рассматриваемых как доказательства в логике гильбертова. ниже.

Если ограничиться имплицитным интуиционистским фрагментом, простой способ формализовать логику в стиле Гильберта состоит в следующем. Пусть Γ - конечный набор формул, рассматриваемых как гипотезы. Тогда δ равно выводимый из Γ, обозначим Γ ⊢ δ, в следующих случаях:

  • δ - гипотеза, т. е. формула Γ,
  • δ - пример схемы аксиом; то есть по наиболее распространенной системе аксиом:
    • δ имеет вид α → (βα), или же
    • δ имеет вид (α → (β → Γ)) → ((αβ) → (α → Γ)),
  • δ следует по дедукции, т. е. для некоторого α, обе αδ и α уже выводимы из Γ (это правило modus ponens )

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

Типизированная комбинаторная логика может быть сформулирована с использованием аналогичного синтаксиса: пусть Γ - конечный набор переменных, аннотированных их типами. Терм T (также помеченный его типом) будет зависеть от этих переменных [Γ ⊢ T:δ] когда:

  • T - одна из переменных в Γ,
  • T - базовый комбинатор; т.е. под наиболее распространенным комбинаторным базисом:
    • Т - К:α → (βα) [куда α и β обозначают типы его аргументов], или
    • T - S :(α → (β → Γ)) → ((αβ) → (α → Γ)),
  • T - композиция двух подтермов, зависящих от переменных в Γ.

Определенные здесь правила генерации приведены в правом столбце ниже. Замечание Карри просто утверждает, что оба столбца находятся во взаимно однозначном соответствии. Ограничение переписки с интуиционистская логика означает, что некоторые классический тавтологии, Такие как Закон Пирса ((αβ) → α) → α, исключены из переписки.

Интуиционистская импликационная логика в гильбертовом стилеПросто типизированная комбинаторная логика

На более абстрактном уровне соответствие можно переформулировать, как показано в следующей таблице. Особенно теорема дедукции специфическая для логики Гильберта соответствует процессу устранение абстракции комбинаторной логики.

Логическая сторонаСторона программирования
предположениеПеременная
аксиомыкомбинаторы
modus ponensзаявление
теорема дедукцииустранение абстракции

Благодаря соответствию результаты комбинаторной логики могут быть перенесены в логику гильбертова и наоборот. Например, понятие снижение терминов комбинаторной логики можно перенести в логику гильбертова, и это дает возможность канонически преобразовывать доказательства в другие доказательства того же утверждения. Можно также перенести понятие нормальных терминов на понятие нормальных доказательств, выразив, что гипотезы аксиом никогда не должны быть отделены полностью (поскольку в противном случае может произойти упрощение).

И наоборот, недоказуемость в интуиционистской логике Закон Пирса может быть перенесен обратно в комбинаторную логику: нет типизированного члена комбинаторной логики, который мог бы быть типизирован с типом

((αβ) → α) → α.

Также могут быть перенесены результаты о полноте некоторых наборов комбинаторов или аксиом. Например, тот факт, что комбинатор Икс представляет собой одноточечная основа (экстенсиональной) комбинаторной логики означает, что схема единственной аксиомы

(((α → (β → Γ)) → ((αβ) → (α → Γ))) → ((δ → (εδ)) → ζ)) → ζ,

какой основной тип из Икс, является адекватной заменой комбинации схем аксиом

α → (βα) и
(α → (β → Γ)) → ((αβ) → (α → Γ)).

Естественная дедукция и лямбда-исчисление

После Карри подчеркнул синтаксическое соответствие между Дедукция в стиле Гильберта и комбинаторная логика, Говард в 1969 году явным образом проявилась синтаксическая аналогия между программами просто типизированное лямбда-исчисление и доказательства естественный вычет. Ниже левая часть формализует интуиционистский импликационный естественный вывод как исчисление секвенты (использование секвенций является стандартным при обсуждении изоморфизма Карри – Ховарда, поскольку оно позволяет сформулировать правила дедукции более четко) с неявным ослаблением, а правая часть показывает правила типизации лямбда-исчисление. В левой части Γ, Γ1 и Γ2 обозначают упорядоченные последовательности формул, в то время как в правой части они обозначают последовательности именованных (т. е. типизированных) формул с разными именами.

Интуиционистская импликационная естественная дедукцияПравила присвоения типов лямбда-исчисления

Перефразируя соответствие, доказывая, что Γ ⊢ α означает наличие программы, которая при заданных значениях типов, перечисленных в Γ, производит объект типа α. Аксиома соответствует введению новой переменной с новым, неограниченным типом, → я соответствует абстракции функции, а → E Правило соответствует применению функции. Заметим, что соответствие не является точным, если в качестве контекста Γ взять набор формул как, например, λ-термины λx.λy.Икс и λx.λy.у типа ααα не будет отличаться в переписке. Приведены примеры ниже.

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

Логическая сторонаСторона программирования
аксиомаПеременная
правило введенияконструктор
правило исключениядеструктор
нормальный вычетнормальная форма
нормализация вычетовслабая нормализация
доказуемостьтип обитания проблема
интуиционистская тавтологияжилой тип

Соответствие Говарда естественным образом распространяется на другие расширения естественный вычет и просто типизированное лямбда-исчисление. Вот неполный список:

Классическая логика и операторы управления

Во времена Карри, а также во времена Ховарда, корреспонденция доказательств как программ касалась только интуиционистская логика, т.е. логика, в которой, в частности, Закон Пирса был нет выводимый. Расширение соответствия закону Пирса и, следовательно, к классическая логика стало ясно из работы Гриффина над операторами ввода, которые фиксируют контекст оценки выполнения данной программы, так что этот контекст оценки может быть позже переустановлен. Ниже приводится базовое соответствие в стиле Карри – Ховарда для классической логики. Обратите внимание на соответствие между перевод двойного отрицания используется для сопоставления классических доказательств с интуиционистской логикой и стиль прохождения перевод, используемый для сопоставления лямбда-терминов, включающих управление, в чистые лямбда-термины. В частности, переводы в стиле продолжения по имени относятся к Колмогоров перевод с двойным отрицанием и перевод в стиле «продолжение-передача по значению» относится к разновидности перевода с двойным отрицанием, созданного Куродой.

Логическая сторонаСторона программирования
Закон Пирса: ((αβ) → α) → αвызов с текущим продолжением
перевод двойного отрицанияперевод в стиле продолжения

Более точное соответствие Карри – Ховарда существует для классической логики, если определить классическую логику не добавлением аксиомы, такой как Закон Пирса, но сделав несколько выводов в последующих. В случае классической естественной дедукции существует соответствие доказательств как программ типизированным программам Париго. λμ-исчисление.

Последовательное исчисление

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

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

Логическая сторонаСторона программирования
вырезать устранениередукция в виде абстрактной машины
правильные правила введенияконструкторы кода
оставил правила введенияконструкторы стеков оценки
приоритет правой стороны при устранении порезоввызов по имени снижение
приоритет левой стороны при отсечениивызов по стоимости снижение

Связанные соответствия доказательств как программ

Роль де Брёйна

Н. Г. де Брёйн использовал лямбда-нотацию для представления доказательств средства проверки теорем Автомат, и представил предложения как «категории» их доказательств. Это было в конце 1960-х, в то же время, когда Ховард писал свою рукопись; де Брюйн, вероятно, не знал о работе Ховарда и независимо изложил переписку (Sørensen & Urzyczyn [1998] 2006, стр. 98–99). Некоторые исследователи склонны использовать термин «соответствие Карри – Ховарда – де Брейна» вместо «корреспонденция Карри – Ховарда».

Толкование BHK

В Толкование BHK интерпретирует интуиционистские доказательства как функции, но не определяет класс функций, релевантных для интерпретации. Если взять лямбда-исчисление для этого класса функций, то Интерпретация BHK говорит то же самое, что и соответствие Говарда между естественной дедукцией и лямбда-исчислением.

Реализуемость

Клини рекурсивный осуществимость разбивает доказательства интуиционистской арифметики на пару рекурсивной функции и доказательства формулы, выражающей то, что рекурсивная функция «реализует», т.е. правильно инстанцирует дизъюнкции и экзистенциальные кванторы исходной формулы, так что формула становится истинной.

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

Гёдель с диалектическая интерпретация реализует (расширение) интуиционистской арифметики с вычислимыми функциями. Связь с лямбда-исчислением неясна даже в случае естественной дедукции.

Переписка Карри – Ховарда – Ламбека

Иоахим Ламбек показали в начале 1970-х, что доказательства интуиционистской логики высказываний и комбинаторы типизированных комбинаторная логика разделяют общую эквациональную теорию, которая является одной из декартово закрытые категории. Выражение «соответствие Карри – Ховарда – Ламбека» теперь используется некоторыми людьми для обозначения трехстороннего изоморфизма между интуиционистской логикой, типизированным лямбда-исчислением и декартово закрытыми категориями, при этом объекты интерпретируются как типы или предложения, а морфизмы - как термины или доказательства.Соответствие работает на эквациональном уровне и не является выражением синтаксической идентичности структур, как это имеет место для каждого из соответствий Карри и Ховарда: т.е. структура четко определенного морфизма в декартово-замкнутой категории не сравнима с структура доказательства соответствующего суждения либо в логике гильбертова, либо в естественной дедукции. Чтобы прояснить это различие, ниже перефразируется основная синтаксическая структура декартовых закрытых категорий.

Объекты (типы) определяются

  • это объект
  • если α и β объекты тогда и являются объектами.

Морфизмы (термины) определяются как

  • , , , и морфизмы
  • если т это морфизм, λ t это морфизм
  • если т и ты морфизмы, и являются морфизмами.

Хорошо определенные морфизмы (типизированные термины) определяются следующими правила набора текста (в котором обычная запись категориального морфизма заменяется на последовательное исчисление обозначение ).

Личность:

Сочинение:

Тип объекта (конечный объект ):

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

Левая и правая проекция:

Каррирование:

Заявление:

Наконец, уравнения категории имеют вид

  • (если набрано правильно)

Из этих уравнений следует следующее -законы:

Теперь существует т такой, что если только доказуемо в импликативной интуиционистской логике.

Примеры

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

Комбинатор идентичности рассматривается как доказательство αα в логике гильберта

В качестве примера рассмотрим доказательство теоремы αα. В лямбда-исчисление, это тип тождественной функции я = λИкс.Икс а в комбинаторной логике тождественная функция получается применением S = λfgx.FX(gx) дважды K = λху.Икс. То есть, я = ((S K) K). В качестве описания доказательства здесь говорится, что следующие шаги могут быть использованы для доказательства αα:

  • создать вторую схему аксиом с формулами α, βα и α получить доказательство (α → ((βα) → α)) → ((α → (βα)) → (αα)),
  • создать экземпляр первой схемы аксиом один раз с α и βα получить доказательство α → ((βα) → α),
  • создать экземпляр первой схемы аксиом во второй раз с α и β получить доказательство α → (βα),
  • дважды примените modus ponens, чтобы получить доказательство αα

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

  1. Сначала докажите теоремы, соответствующие типам п и Q.
  2. С п применяется к Q, тип п должен иметь форму αβ и тип Q должен иметь форму α для некоторых α и β. Поэтому вывод можно оторвать, β, с помощью правила modus ponens.

Комбинатор композиции рассматривается как доказательство (βα) → (Γ → β) → Γ → α в логике гильберта

В качестве более сложного примера рассмотрим теорему, которая соответствует B функция. Тип B является (βα) → (Γ → β) → Γ → α. B эквивалентно (S (K S) K). Это наша дорожная карта для доказательства теоремы (βα) → (Γ → β) → Γ → α.

Первый шаг - построить (K S). Чтобы сделать антецедент K аксиома выглядит как S аксиома, набор α равно (αβ → Γ) → (αβ) → α → Γ, и β равно δ (чтобы избежать коллизий переменных):

K : αβα
K[α = (αβ → Γ) → (αβ) → α → Γ, β= δ]: ((αβ → Γ) → (αβ) → α → Γ) → δ → (αβ → Γ) → (αβ) → α → Γ

Поскольку антецедент здесь просто S, консеквент можно отделить с помощью Modus Ponens:

K S : δ → (αβ → Γ) → (αβ) → α → Γ

Это теорема, соответствующая типу (K S). Теперь подайте заявку S к этому выражению. Принимая S следующее

S : (αβ → Γ) → (αβ) → α → Γ,

положить α = δ, β = αβ → Γ, и Γ = (αβ) → α → Γ, уступая

S[α = δ, β = αβ → Γ, Γ = (αβ) → α → Γ]: (δ → (αβ → Γ) → (αβ) → α → Γ) → (δ → (αβ → Γ)) → δ → (αβ) → α → Γ

а затем отделите следствие:

S (K S) : (δ → αβ → Γ) → δ → (αβ) → α → Γ

Это формула для типа (S (K S)). Частный случай этой теоремы имеет δ = (β → Γ):

S (K S)[δ = β → Γ]: ((β → Γ) → αβ → Γ) → (β → Γ) → (αβ) → α → Γ

Эта последняя формула должна применяться к K. Специализироваться K снова, на этот раз заменив α с (β → Γ) и β с α:

K : αβα
K[α = β → Γ, β = α] : (β → Γ) → α → (β → Γ)

Это то же самое, что и антецедент предыдущей формулы, поэтому отсоединение следствия:

S (K S) K : (β → Γ) → (αβ) → α → Γ

Переключение имен переменных α и γ дает нам

(βα) → (Γ → β) → Γ → α

что оставалось доказать.

Нормальное доказательство (βα) → (Γ → β) → Γ → α в естественной дедукции рассматривается как λ-член

На диаграмме ниже показано (βα) → (Γ → β) → Γ → α в естественной дедукции и показывает, как это можно интерпретировать как λ-выражение λ а. λ б. λ грамм.(а (б грамм)) типа (βα) → (Γ → β) → Γ → α.

                                     a: β → α, b: γ → β, g: γ ⊢ b: γ → β a: β → α, b: γ → β, g: γ ⊢ g: γ —————————— ——————————————————————————————————————————————————— ——————————————————————————————————————————— а: β → α, б : γ → β, g: γ ⊢ a: β → α a: β → α, b: γ → β, g: γ ⊢ bg: β —————————————————— ——————————————————————————————————————————————————— ————— a: β → α, b: γ → β, g: γ ⊢ a (bg): α ———————————————————————— ————————————— a: β → α, b: γ → β ⊢ λ g. a (bg): γ → α ————————————————————————————————————————— β → α ⊢ λ б. λ г. a (bg): (γ → β) -> γ → α ——————————————————————————————————— - ⊢ λ a. λ б. λ г. a (b g): (β → α) -> (γ → β) -> γ → α

Другие приложения

Недавно изоморфизм был предложен как способ определения разбиения пространства поиска в генетическое программирование.[9] Метод индексирует наборы генотипов (программные деревья, разработанные системой GP) на основе их изоморфного доказательства Карри – Ховарда (называемого видами).

Как отмечает INRIA директор по исследованиям Бернард Ланг,[10] Соответствие Карри-Ховарда представляет собой аргумент против патентоспособности программного обеспечения: поскольку алгоритмы являются математическими доказательствами, патентоспособность первого подразумевала бы патентоспособность второго. Теорема может быть частной собственностью; математику придется платить за его использование и доверять компании, которая его продает, но хранит доказательства в секрете и отказывается от ответственности за любые ошибки.

Обобщения

Перечисленные здесь соответствия идут намного дальше и глубже. Например, декартовы закрытые категории обобщаются закрытые моноидальные категории. В внутренний язык из этих категорий система линейного типа (соответствует линейная логика ), который обобщает просто типизированное лямбда-исчисление как внутренний язык декартовых закрытых категорий. Более того, можно показать, что они соответствуют кобордизмы,[11] которые играют жизненно важную роль в теория струн.

Расширенный набор эквивалентностей также исследуется в теория гомотопического типа, которая стала очень активной областью исследований примерно в 2013 г., а по состоянию на 2018 г. все еще.[12] Здесь, теория типов расширяется аксиома однолистности («эквивалентность эквивалентна равенству»), что позволяет использовать теорию гомотопического типа в качестве основы для всей математики (включая теория множеств и классическая логика, открывая новые способы обсуждения аксиома выбора и многое другое). То есть соответствие Карри – Ховарда о том, что доказательства являются элементами обитаемых типов, обобщается до понятия гомотопическая эквивалентность доказательств (как пути в пространстве, Тип идентификации или же тип равенства теории типов, интерпретируемой как путь).[13]

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

  1. ^ Впервые переписка была выражена в Говард 1980. См., Например, раздел 4.6, стр.53. Герт Смолка и Ян Швингхаммер (2007-8), Конспекты лекций по семантике
  2. ^ Интерпретация Брауэра – Гейтинга – Колмогорова также называется «интерпретацией доказательства»: с. 161 Джульетт Кеннеди, Роман Коссак, ред. 2011 г. Теория множеств, арифметика и основы математики: теоремы, философии ISBN  978-1-107-00804-5
  3. ^ Карри 1934.
  4. ^ Карри и Фейс 1958.
  5. ^ Говард 1980.
  6. ^ Моджи, Эухенио (1991), «Понятия вычислений и монад» (PDF), Информация и вычисления, 93 (1): 55–92, Дои:10.1016/0890-5401(91)90052-4
  7. ^ Соренсон, Мортен; Уржичин, Павел (1998), Лекции об изоморфизме Карри-Ховарда, CiteSeerX  10.1.1.17.7385
  8. ^ Гольдблатт, «7.6 Топология Гротендика как интуиционистская модальность» (PDF), Математическая модальная логика: модель ее развития, стр. 76–81. Упомянутая "слабая" модальность от Наклонился на; Бирман; де Пайва (1998), «Вычислительные типы с логической точки зрения», Журнал функционального программирования, 8 (2): 177–193, CiteSeerX  10.1.1.258.6004, Дои:10.1017 / s0956796898002998
  9. ^ Ф. Бинард и А. Фелти, "Генетическое программирование с полиморфными типами и функциями высшего порядка". В Труды 10-й ежегодной конференции по генетическим и эволюционным вычислениям, страницы 1187 1194, 2008.[1]
  10. ^ "Статья". bat8.inria.fr. Получено 2020-01-31.
  11. ^ Джон с. Баэз и Майк Стэйт "Физика, топология, логика и вычисления: розеттский камень ", (2009) ArXiv 0903.0340 в Новые структуры для физики, изд. Боб Кок, Конспект лекций по физике т. 813, Springer, Berlin, 2011, стр. 95–174.
  12. ^ "теория гомотопических типов - Google Trends". Trends.google.com. Получено 2018-01-26.
  13. ^ Теория гомотопических типов: однолистные основы математики. (2013) Программа Univalent Foundations. Институт перспективных исследований.

Семинальные ссылки

  • Карри, Эйч Би (1934-09-20). «Функциональность в комбинаторной логике». Труды Национальной академии наук Соединенных Штатов Америки. 20 (11): 584–90. Bibcode:1934ПНАС ... 20..584С. Дои:10.1073 / пнас.20.11.584. ISSN  0027-8424. ЧВК  1076489. PMID  16577644.
  • Карри, Haskell B; Фейс, Роберт (1958). Крейг, Уильям (ред.). Комбинаторная логика. Исследования по логике и основам математики. 1. Издательская компания Северной Голландии. LCCN  a59001593; с двумя разделами Крейга, Уильяма; см. пункт 9E
  • Де Брёйн, Николаас (1968), Automath, язык математики, Факультет математики Технологического университета Эйндховена, TH-report 68-WSK-05. Перепечатано в измененной форме с комментариями на двух страницах в: Автоматизация и рассуждение, том 2, Классические статьи по вычислительной логике 1967–1970, Springer Verlag, 1983, стр. 159–200.
  • Ховард, Уильям А. (сентябрь 1980 г.) [оригинальная рукопись статьи 1969 г.], «Понятие построения формул как типов», в Селдин, Джонатан П.; Хиндли, Дж. Роджер (ред.), Х. Карри: Очерки комбинаторной логики, лямбда-исчисления и формализма, Академическая пресса, стр. 479–490, ISBN  978-0-12-349050-6.

Продления переписки

  1. ^ а б Пфеннинг, Франк; Дэвис, Роуэн (2001), "Судебная реконструкция модальной логики" (PDF), Математические структуры в информатике, 11 (4): 511–540, CiteSeerX  10.1.1.43.1611, Дои:10.1017 / S0960129501003322
  2. ^ Дэвис, Роуэн; Пфеннинг, Франк (2001), «Модальный анализ поэтапных вычислений» (PDF), Журнал ACM, 48 (3): 555–604, CiteSeerX  10.1.1.3.5442, Дои:10.1145/382780.382785, S2CID  52148006
  • Гриффин, Тимоти Г. (1990), "Формулы как типы, понятие управления", Конф. Рекорд 17-го ежегодного симпозиума ACM. по принципам языков программирования, POPL '90, Сан-Франциско, Калифорния, США, 17–19 января 1990 г., стр. 47–57, Дои:10.1145/96709.96714, ISBN  978-0-89791-343-0, S2CID  3005134.
  • Париго, Мишель (1992), "Лямбда-мю-исчисление: алгоритмическая интерпретация классической естественной дедукции", Международная конференция по логическому программированию и автоматизированному рассуждению: Труды LPAR '92, Санкт-Петербург, Россия, Конспект лекций по информатике, 624, Springer-Verlag, стр. 190–201, ISBN  978-3-540-55727-2.
  • Гербелин, Хьюго (1995), "Структура лямбда-исчисления, изоморфная структуре секвенциального исчисления в стиле Гентцена", в Пачольски, Лешек; Тюрин, Ежи (ред.), Логика компьютерных наук, 8-й международный семинар, CSL '94, Казимеж, Польша, 25–30 сентября 1994 г., Избранные статьи, Конспект лекций по информатике, 933, Springer-Verlag, стр. 61–75, ISBN  978-3-540-60017-6.
  • Габбай, Дов; де Кейруш, Руи (1992). «Расширение интерпретации Карри-Ховарда на линейные, релевантные и другие логики ресурсов». Журнал символической логики. Журнал символической логики. 57. С. 1319–1365. Дои:10.2307/2275370. JSTOR  2275370.. (Полная версия статьи представлена ​​на Коллоквиум по логике '90, Хельсинки. Аннотация в JSL 56(3):1139–1140, 1991.)
  • де Кейруш, Руи; Габбай, Дов (1994), «Равенство в помеченных дедуктивных системах и функциональная интерпретация пропозиционального равенства», в Dekker, Paul; Стохоф, Мартин (ред.), Материалы девятого Амстердамского коллоквиума, ILLC / Департамент философии Амстердамского университета, стр. 547–565, ISBN  978-90-74795-07-4.
  • де Кейруш, Руи; Габбай, Дов (1995), «Функциональная интерпретация квантификатора существования», Бюллетень Группы интересов по чистой и прикладной логике, 3, стр. 243–290. (Полная версия статьи представлена ​​на Коллоквиум по логике '91, Упсала. Аннотация в JSL 58(2):753–754, 1993.)
  • де Кейруш, Руи; Габбай, Дов (1997), «Функциональная интерпретация модальной необходимости», in de Rijke, Maarten (ed.), Достижения в области интеллектуальной логики, Серия прикладной логики, 7, Springer-Verlag, стр. 61–91, ISBN  978-0-7923-4711-8.
  • де Кейруш, Руи; Габбай, Дов (1999), «Естественный вычет с ярлыком» в Ольбахе, Ханс-Юрген; Рейл, Уве (ред.), Логика, язык и рассуждение. Очерки в честь Дов Габбая, Тенденции в логике, 7, Kluwer, стр. 173–250, ISBN  978-0-7923-5687-5.
  • де Оливейра, Анжолина; де Кейрос, Руи (1999), "Процедура нормализации для фрагмента уравнения помеченного естественного выведения", Логический журнал группы по интересам чистой и прикладной логики, 7, Oxford University Press, стр. 173–215. (Полная версия статьи представлена ​​на 2-й WoLLIC'95, Ресифи. Аннотация в Журнал Группы интересов по чистой и прикладной логике 4(2):330–332, 1996.)
  • Поэрномо, Иман; Кроссли, Джон; Wirsing; Мартин (2005), Адаптация Proofs-as-Programs: протокол Карри – Ховарда, Монографии по информатике, Springer, ISBN  978-0-387-23759-6, касается адаптации синтеза программ «доказательства как программы» к грубым и императивным задачам разработки программ с помощью метода, который авторы называют протоколом Карри – Ховарда. Включает обсуждение соответствия Карри – Ховарда с точки зрения компьютерных наук.
  • de Queiroz, Ruy J.G.B .; де Оливейра, Анжолина (2011), "Функциональная интерпретация прямых вычислений", Электронные заметки по теоретической информатике, Эльзевир, 269: 19–40, Дои:10.1016 / j.entcs.2011.03.003. (Полная версия статьи представлена ​​на LSFA 2010, Натал, Бразилия.)

Философские интерпретации

Синтетические бумаги

Книги

  • Де Гроот, Филипп, изд. (1995), Изоморфизм Карри – Ховарда, Cahiers du Centre de Logique (Католический университет Лувена), 8, Academia-Bruylant, ISBN  978-2-87209-363-2, воспроизводит основополагающие статьи Карри-Фейса и Ховарда, статью де Брейна и несколько других статей.
  • Соренсен, Мортен Гейне; Уржичин, Павел (2006) [1998], Лекции об изоморфизме Карри – Ховарда, Исследования по логике и основам математики, 149, Elsevier Science, CiteSeerX  10.1.1.17.7385, ISBN  978-0-444-52077-7, примечания по теории доказательств и теории типов, который включает представление соответствия Карри – Ховарда, с акцентом на соответствие формул как типов
  • Жирар, Жан-Ив (1987–1990), Доказательства и типы, Кембриджские трактаты по теоретической информатике, 7, Перевод и с приложениями Лафон, Ив и Тейлор, Пол, Cambridge University Press, ISBN  0-521-37181-3, заархивировано из оригинал на 2008-04-18, заметки по теории доказательств с изложением соответствия Карри – Ховарда.
  • Томпсон, Саймон (1991), Теория типов и функциональное программирование, Эддисон – Уэсли, ISBN  0-201-41667-0.
  • Поэрномо, Иман; Кроссли, Джон; Wirsing; Мартин (2005), Адаптация Proofs-as-Programs: протокол Карри – Ховарда, Монографии по информатике, Springer, ISBN  978-0-387-23759-6, касается адаптации синтеза программ «доказательства как программы» к грубым и императивным задачам разработки программ с помощью метода, который авторы называют протоколом Карри – Ховарда. Включает обсуждение соответствия Карри – Ховарда с точки зрения компьютерных наук.
  • Binard, F .; Фелти, А. (2008), «Генетическое программирование с полиморфными типами и функциями высшего порядка» (PDF), Материалы 10-й ежегодной конференции по генетическим и эволюционным вычислениям, Ассоциация вычислительной техники, стр. 1187–94, Дои:10.1145/1389095.1389330, ISBN  9781605581309, S2CID  3669630
  • de Queiroz, Ruy J.G.B .; де Оливейра, Анжолина Дж .; Габбай, Дов М. (2011), Функциональная интерпретация логической дедукции, Достижения в логике, 5, Imperial College Press / World Scientific, ISBN  978-981-4360-95-1.

дальнейшее чтение

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