Система F

Систе́ма F (полімо́рфне ля́мбда-чи́слення, систе́ма , типізо́ване ля́мбда-чи́слення дру́гого поря́дку) — система типізованого лямбда-числення, що відрізняється від просто типізованої системи наявністю механізму універсальної квантифікації над типами. Цю систему розробив 1972 року Жан-Ів Жирар[en][1] у контексті теорії доведень у логіці. Незалежно від нього подібну систему запропонував 1974 року Джон Рейнольдс[en][2]. Система F дозволяє формалізувати концепцію параметричного поліморфізму в мовах програмування та слугує теоретичною основою для таких мов програмування як Haskell та ML.

Система F допускає конструювання термів, залежних від типів. Технічно це досягається через механізм абстрагування терму за типом, що в результаті дає новий терм. Традиційно для такої абстракції використовують символ великої лямбди . Наприклад, взявши терм типу та абстрагуючись за змінною типу , отримуємо терм . Цей терм є функцією з типів у терми. Застосовуючи цю функцію до різних типів, ми отримуватимемо терми з ідентичною структурою, але різними типами:

 — терм типу ;
 — терм типу .

Видно, що терм має поліморфну поведінку, тобто задає спільний інтерфейс для різних типів даних. У системі F цьому терму приписується тип . Квантор загальності в типі підкреслює можливість підстановки замість змінної типу будь-якого допустимого типу.

Формальний опис

Синтаксис типів

Типи Системи F конструюються із набору змінних типу за допомогою операторів і . За традицією для змінних типу використовують грецькі літери. Правила формування типів такі:

  • (Змінна типу) Якщо  — змінна типу, то  — це тип;
  • (Стрілковий тип) Якщо і є типами, то  — це тип;
  • (Універсальний тип) Якщо є змінною типу, а  — типом, то  — це тип.

Зовнішні дужки часто опускають, оператор вважають правоасоціативним, а дію оператора такою, що продовжується праворуч наскільки це можливо. Наприклад,  — стандартне скорочення для .

Синтаксис термів

Терми системи F конструюються з набору термових змінних (, , і т. д.) за такими правилами

  • (Змінна) Якщо  — змінна, то  — це терм;
  • (Абстракція) Якщо є змінною,  — типом, а  — термом, то  — це терм;
  • (Застосування) Якщо і є термами, то  — це терм;
  • (Універсальна абстракція) Якщо є змінною типу, а  — термом, то  — це терм;
  • (Універсальне застосування) Якщо є термом, а  — типом, то  — це терм.

Зовнішні дужки часто опускають, обидва сорти застосування вважають лівоасоціативними, а дію абстракцій — такою, що продовжується вправо наскільки це можливо.

Розрізняють дві версії просто типізованої системи. Якщо, як у наведених вище правилах, термові змінні в лямбда-абстракції анотуються типами, то систему називають типізованою за Чорчем. Якщо ж правило абстракції замінити на

  • (Абстракція за Каррі) Якщо є змінною, а  — термом, то  — це терм, і відкинути два останні правила, то систему називають типізованою за Каррі. Фактично, терми системи, типізованої за Каррі, ті самі, що й у безтиповому лямбда-численні.

Правила редукції

Крім стандартного для лямбда-обчислення правила -редукції

у системі F у стилі Чорча вводиться додаткове правило,

,

що дозволяє обчислювати застосування терму до типу через механізм підстановки типу замість змінної типу.

Контексти типізації та затвердження типізації

Контекстом, як і в просто типізованому лямбда-обчисленні, називають множину тверджень про приписування типів різним змінним, розділених комою

У контекст можна додати «свіжу» для цього контексту змінну: якщо  — допустимий контекст, який не містить змінної , а  — тип, то  — теж допустимий контекст.

Загальний вигляд твердження про типізацію такий:

Це читається так: у контексті терм має тип .

Правила типізації за Чорчем

У системі F, типізованій за Чорчем, типи термам приписують за такими правилами: (Початкове правило) Якщо змінна пирсутня в контексті з типом , то в цьому контексті має тип . У вигляді правила виведення

(Правило введення ) Якщо в деякому контексті, розширеному твердженням, що має тип , терм має тип , то в згаданому контексті (без ), лямбда-абстракція має тип . У вигляді правила виведення

(Правило видалення ) Якщо в деякому контексті терм має тип , а терм має тип , то застосування має тип . У вигляді правила виведення

(Правило введення ) Якщо в деякому контексті терм має тип , то в цьому контексті терм має тип . У вигляді правила виведення

Це правило вимагає застереження: змінна типу не повинна зустрічатися у твердженнях типізації контексту .

(Правило видалення ) Якщо в деякому контексті терм має тип , і  — це тип, то в цьому контексті терм має тип . У вигляді правила виведення

Правила типізації за Каррі

У системі F, типізованій за Каррі, приписування типів терм здійснюється відповідно до таких правил: (Початкове правило) Якщо змінна в контексті присутня з типом , то в цьому контексті має тип . У вигляді правила виведення

(Правило введення ) Якщо в деякому контексті, розширеному твердженням, що має тип , терм має тип , то в згаданому контексті (без ), лямбда-абстракція має тип . У вигляді правила виведення

(Правило видалення ) Якщо в деякому контексті терм має тип , а терм має тип , то застосування має тип . У вигляді правила виведення

(Правило введення ) Якщо в деякому контексті терм має тип , то в цьому контексті цьому терму можна приписати і тип . У вигляді правила виведення

Це правило вимагає застереження: змінна типу не повинна зустрічатися у твердженнях типізації контексту .

(Правило видалення ) Якщо в деякому контексті терм має тип , і  — це тип, то в цьому контексті цьому терму можна приписати й тип . У вигляді правила виведення

Приклад

За початковим правилом:

Застосуємо правило видалення , взявши як тип

Тепер за правилом видалення маємо можливість застосувати терм сам до себе

і, нарешті, за правилом введення

Це приклад терму, що типізується в системі F, але не в просто типізованій системі .

Подання типів даних

Система F має достатні виражальні засоби, для того щоб безпосередньо реалізувати багато типів даних, що використовуються в мовах програмування. Працюватимемо у версії Чорча системи F.

Порожній тип. Тип

ненаселений у системі F, тобто у ній відсутні терми з таким типом.

Одиничний тип. У типу

в системі F є єдиний мешканець, що перебуває в нормальній формі, — терм.

.

Булів тип. У системі F задається так:

.

У цього типу рівно два мешканці, ототожнювані з двома булевими константами.

Конструкція умовного оператора

Ця функція відповідає природним вимогам

і

для довільного типу та довільних і . У цьому легко переконатися, розкривши визначення та виконавши -редукції.

Тип добутку. Для довільних типів і тип їх декартового твору

населений парою

для кожних і . Проєкції пари задаються функціями

Ці функції відповідають природним вимогам і .

Тип суми. Для довільних типів і тип їх суми

населений або термом типу , або термом типу , залежно від застосованого конструктора

Тут , . Функція, що здійснює розбір випадків (порівняння зі взірцем), має вигляд

Ця функція відповідає таким природним вимогам

і

для довільних типів , і та довільних термів і .

Числа Чорча. Тип натуральних чисел у системі F

населений нескінченною кількістю різних елементів, одержуваних за допомогою двох конструкторів і :

Натуральне число можна отримати застосувавши разів другий конструктор до першого або, еквівалентно, подати термом

Властивості

  • Просто типізована система має властивість ти́пової безпеки: при -редукціях тип лямбда-терму залишається незмінним, а сама типізація не заважає перебігу обчислень.
  • У своїй дисертації Жан-Ів Жирар[en] показав[1], що система F має властивість сильної нормалізації: будь-який допустимий терм за скінченне число -редукцій зводиться до єдиної нормальної форми.
  • Система F є імпредикативною системою, оскільки змінна типу, що зв'язується квантором загальності при визначенні універсального типу, може заміщатися самим об'єктом, що визначається. Наприклад, терм одиничного типу можна застосувати до власного типу, породжуючи терм типу . Як показав Джо Веллз (Joe Wells) 1994 року[3], задача виведення типів для версії Каррі системи F нерозв'язна. Тому при практичній реалізації мов програмування зазвичай використовують обмежені, предикативні версії поліморфізму: пренекс-поліморфізм (поліморфізм у стилі ML), поліморфізм рангу 2 тощо. У разі пренекс-поліморфізму областю визначення змінних типу є лише типи без кванторів. У цих системах задачу виведення типів можна розв'язати, такий висновок базується на алгоритмі Гіндлі — Мілнера.
  • Відповідність Каррі — Говарда пов'язує систему F із мінімальною інтуїціоністською логікою висловлювань другого порядку[en], формули якої побудовано з пропозиційних змінних за допомогою імплікації та універсальної квантифікації за висловлюваннями. При цьому значення (істина), (брехня), зв'язки (заперечення), (кон'юнкція) та (диз'юнкція), а також (квантор існування) можна визначити так

Зазначимо, що відповідність Каррі — Говарда ставить у відповідність до істини — одиничний тип, брехні — порожній тип, кон'юнкції — добуток типів, а диз'юнкції — їх суму.

Примітки

  1. а б Girard, Jean-Yves. Interprétation fonctionnelle et élimination des coupures de l’arithmétique d’ordre supérieur. — Université Paris 7, 1972.
  2. John C. Reynolds. Towards a Theory of Type Structure : [арх. 31 жовтня 2014]. — 1974.
  3. Wells J. B. Typability and type checking in the second-order lambda-calculus are equivalent and undecidable : [арх. 22 лютого 2007] // Proceedings of the 9th Annual IEEE Symposium on Logic in Computer Science (LICS). — 1994. — С. 176–185.

Література