Неразрешимость задачи вывода типов в языке с зависимыми типами — различия между версиями
(<tex> вместо <math>) |
(Викификация) |
||
Строка 1: | Строка 1: | ||
=<tex dpi = "180">\lambda\Pi</tex>-исчисление= | =<tex dpi = "180">\lambda\Pi</tex>-исчисление= | ||
− | Множество ''термов'' рекурсивно определяется следующей грамматикой: | + | {{Определение|definition=Множество '''термов''' рекурсивно определяется следующей грамматикой: |
<tex>\displaystyle T ::= \mathrm{Type} \mid \mathrm{Kind} \mid x \mid \left(T T\right) \mid \lambda x : T . T \mid \Pi x : T . T</tex>. | <tex>\displaystyle T ::= \mathrm{Type} \mid \mathrm{Kind} \mid x \mid \left(T T\right) \mid \lambda x : T . T \mid \Pi x : T . T</tex>. | ||
− | Термы <tex>\mathrm{Type}</tex> и <tex>\mathrm{Kind}</tex> называются ''сортами'', <tex>x</tex> {{---}} ''переменными'', <tex>(t t')</tex> {{---}} ''применениями'', <tex>\lambda x : t . t'</tex> {{---}} ''абстракциями'', <tex>\Pi x : t . t'</tex> {{---}} произведениями. Обозначение <tex>t \rightarrow t'</tex> используется вместо <tex>\Pi x : t . t'</tex>, если <tex>x</tex> не входит свободно в <tex>t'</tex>. | + | Термы <tex>\mathrm{Type}</tex> и <tex>\mathrm{Kind}</tex> называются '''сортами''', <tex>x</tex> {{---}} '''переменными''', <tex>(t t')</tex> {{---}} '''применениями''', <tex>\lambda x : t . t'</tex> {{---}} '''абстракциями''', <tex>\Pi x : t . t'</tex> {{---}} '''произведениями'''. Обозначение <tex>t \rightarrow t'</tex> используется вместо <tex>\Pi x : t . t'</tex>, если <tex>x</tex> не входит свободно в <tex>t'</tex>.}} |
Пусть есть термы <tex>t</tex> и <tex>t'</tex> и переменная <tex>x</tex>. Записью <tex>t\left[x \leftarrow t'\right]</tex> обозначается терм, полученный заменой <tex>t'</tex> на <tex>t</tex> в <tex>x</tex>. Запись <tex>t =_\beta t'</tex> означает, что термы <tex>t</tex> и <tex>t'</tex> <tex>\beta</tex>-эквивалентны. | Пусть есть термы <tex>t</tex> и <tex>t'</tex> и переменная <tex>x</tex>. Записью <tex>t\left[x \leftarrow t'\right]</tex> обозначается терм, полученный заменой <tex>t'</tex> на <tex>t</tex> в <tex>x</tex>. Запись <tex>t =_\beta t'</tex> означает, что термы <tex>t</tex> и <tex>t'</tex> <tex>\beta</tex>-эквивалентны. | ||
− | + | {{Определение|definition='''Контекст''' это список пар <tex>x : T</tex>, где <tex>x</tex> {{---}} переменная, <tex>T</tex> {{---}} терм.}} | |
− | ''Контекст'' это список пар <tex>x : T</tex>, где <tex>x</tex> {{---}} переменная, <tex>T</tex> {{---}} терм. | + | {{Определение|definition=Правила вывода для нашего исчисления: |
− | |||
− | Правила вывода для нашего исчисления: | ||
<tex> | <tex> | ||
Строка 26: | Строка 24: | ||
где <tex>s ::= \mathrm{Type} \mid \mathrm{Kind}</tex>. | где <tex>s ::= \mathrm{Type} \mid \mathrm{Kind}</tex>. | ||
− | Терм <tex>t</tex> ''типизируется'' в контексте <tex>\Gamma</tex>, если существует такой терм <tex>T</tex>, что <tex>\Gamma \vdash t : T</tex>. | + | Терм <tex>t</tex> '''типизируется''' в контексте <tex>\Gamma</tex>, если существует такой терм <tex>T</tex>, что <tex>\Gamma \vdash t : T</tex>.}} |
Отношение редуцируемости на типизируемых термах сильно нормализуемо и обладает ромбовидным свойством. Каждый типизируемый терм имеет единственную нормальную форму, два терма эквивалентны, если у них одинаковая нормальная форма. | Отношение редуцируемости на типизируемых термах сильно нормализуемо и обладает ромбовидным свойством. Каждый типизируемый терм имеет единственную нормальную форму, два терма эквивалентны, если у них одинаковая нормальная форма. | ||
Типизируемый в контексте <tex>\Gamma</tex> терм <tex>t</tex> имеет единственный тип с точностью до эквивалентности. | Типизируемый в контексте <tex>\Gamma</tex> терм <tex>t</tex> имеет единственный тип с точностью до эквивалентности. | ||
− | + | {{Определение|definition=Нормальный терм <tex>t</tex>, типизируемый в контекте <tex>\Gamma</tex>, имеет либо вид | |
− | Нормальный терм <tex>t</tex>, типизируемый в контекте <tex>\Gamma</tex>, имеет либо вид | ||
<tex>\displaystyle t = \lambda x_1 : T_1 \ldots \lambda x_n : T_n . \left(x c_1 \ldots c_n\right)</tex>, | <tex>\displaystyle t = \lambda x_1 : T_1 \ldots \lambda x_n : T_n . \left(x c_1 \ldots c_n\right)</tex>, | ||
Строка 40: | Строка 37: | ||
<tex>\displaystyle t = \lambda x_1 : T_1 \ldots \lambda x_n : T_n . \Pi x : P . Q\text{.}</tex> | <tex>\displaystyle t = \lambda x_1 : T_1 \ldots \lambda x_n : T_n . \Pi x : P . Q\text{.}</tex> | ||
− | Согласимся ''первым символом'' <tex>t</tex> называть <tex>x</tex> в первом случае, и <tex>\Pi</tex> во втором. ''Первыми переменными'' <tex>t</tex> будем называть переменные <tex>x_1, \ldots, x_n</tex>. | + | Согласимся '''первым символом''' <tex>t</tex> называть <tex>x</tex> в первом случае, и <tex>\Pi</tex> во втором. '''Первыми переменными''' <tex>t</tex> будем называть переменные <tex>x_1, \ldots, x_n</tex>.}} |
Версия 18:48, 17 января 2017
-исчисление
Определение: |
Множество термов рекурсивно определяется следующей грамматикой:
Термы . и называются сортами, — переменными, — применениями, — абстракциями, — произведениями. Обозначение используется вместо , если не входит свободно в . |
Пусть есть термы и и переменная . Записью обозначается терм, полученный заменой на в . Запись означает, что термы и -эквивалентны.
Определение: |
Контекст это список пар | , где — переменная, — терм.
Определение: |
Правила вывода для нашего исчисления:
где Терм . типизируется в контексте , если существует такой терм , что . |
Отношение редуцируемости на типизируемых термах сильно нормализуемо и обладает ромбовидным свойством. Каждый типизируемый терм имеет единственную нормальную форму, два терма эквивалентны, если у них одинаковая нормальная форма.
Типизируемый в контексте
терм имеет единственный тип с точностью до эквивалентности.Определение: |
Нормальный терм , где это переменная или сорт, либо видСогласимся первым символом называть в первом случае, и во втором. Первыми переменными будем называть переменные . | , типизируемый в контекте , имеет либо вид