WikiDer > FP (язык программирования)
Парадигма | Функциональный уровень |
---|---|
Разработано | Джон Бэкус |
Впервые появился | 1977 |
Диалекты | |
FP84 | |
Под влиянием | |
APL[1] | |
Под влиянием | |
FL, Haskell |
FP (Короче для функциональное программирование)[2] это язык программирования сделано Джон Бэкус поддержать программирование на функциональном уровне[2] парадигма. Это позволяет исключить именованные переменные. Этот язык был представлен в 1977 году. Премия Тьюринга статья «Можно ли освободить программирование от стиля фон Неймана?» с подзаголовком «Функциональный стиль и его алгебра программ». Статья вызвала интерес к исследованиям функционального программирования,[3] в конечном итоге привело к современным функциональным языкам, а не к парадигме функционального уровня, на которую надеялся Бэкус.
В своей дипломной работе Тьюринга Бэкус описал, чем стиль FP отличается от языков, основанных на исчислении ламбы:
Система FP основана на использовании фиксированного набора комбинированных форм, называемых функциональными формами. Они, плюс простые определения, являются единственным средством создания новых функций из существующих; в них не используются переменные или правила подстановки, и они становятся операциями связанной алгебры программ. Все функции системы FP относятся к одному типу: они отображают объекты на объекты и всегда принимают один аргумент.[2]
Сам FP никогда не находил особого применения за пределами академических кругов.[4] В 1980-х годах Бэкус создал следующий язык, FL, который остался исследовательским проектом.
Обзор
В значения что программы FP сопоставляются друг с другом, составляют набор который закрыто под формирование последовательности:
если Икс1,...,Иксп находятся значения, то последовательность 〈Икс1,...,Иксп〉 Также является ценить
Эти значения могут быть построены из любого набора атомов: логических, целых, вещественных, символов и т. Д .:
логический : {Т, F}целое число : {0,1,2,...,∞}персонаж : {'a', 'b', 'c', ...}символ : {Икс,у,...}
⊥ это неопределенный значение, или Нижний. Последовательности сохраняющий дно:
〈Икс1,...,⊥,...,Иксп〉 = ⊥
Программы FP функции ж что каждая карта одна ценить Икс в другой:
ж:Икс представляет ценить что является результатом применения функция ж к ценить Икс
Функции либо примитивны (т.е. предоставляются в среде FP), либо построены из примитивов с помощью программообразующие операции (также называемый функционалы).
Пример примитивной функции: постоянный, который преобразует значение Икс в постоянную функцию Икс. Функции строгий:
ж:⊥ = ⊥
Другой пример примитивной функции - это селектор семейство функций, обозначаемое 1,2,... куда:
я:〈Икс1,...,Иксп〉 = Икся если 1 ≤ я ≤ n = ⊥ иначе
Функционалы
В отличие от примитивных функций, функционалы работают с другими функциями. Например, некоторые функции имеют единица измерения значение, например 0 для добавление и 1 для умножение. Функционал единица измерения производит такой ценить применительно к функция f у которого есть один:
единица + = 0единица × = 1unit foo = ⊥
Это основные функции FP:
сочинение ж∘грамм куда ж∘грамм:Икс = ж:(грамм:Икс)
строительство [ж1,...,жп] куда [ж1,...,жп]:Икс = 〈ж1:Икс,...,жп:Икс〉
условие (час ⇒ ж;грамм) куда (час ⇒ ж;грамм):Икс = ж:Икс если час:Икс = Т = грамм:Икс если час:Икс = F = ⊥ иначе
применить ко всему αж куда αж:〈Икс1,...,Иксп〉 = 〈ж:Икс1,...,ж:Иксп〉
вставка справа /ж куда /ж:〈Икс〉 = Икс и /ж:〈Икс1,Икс2,...,Иксп〉 = ж:〈Икс1,/ж:〈Икс2,...,Иксп>> и /ж:〈 〉 = единица f
вставка слева \ж куда ж:〈Икс〉 = Икс и ж:〈Икс1,Икс2,...,Иксп〉 = ж:〈\ж:〈Икс1,...,Иксп-1〉,Иксп> и ж:〈 〉 = единица f
Уравнительные функции
Помимо построения из примитивов функционалами, функция может быть определена рекурсивно с помощью уравнения, самый простой вид:
ж ≡ Eж
куда Eж является выражение построены из примитивов, других определенных функций и символа функции ж сам, используя функционалы.
FP84
FP84 является расширением FP для включения бесконечные последовательности, определяется программистом комбинирование форм (аналогично тем, которые сам Бэкус добавил к FL, его преемник FP), и ленивая оценка. В отличие от FFP, другой собственной вариации Бэкуса на FP, FP84 проводит четкое различие между объектами и функциями: то есть последние больше не представлены последовательностями первых. Расширения FP84 достигаются путем снятия ограничения FP, согласно которому построение последовательности применяется только к не-Объекты: в FP84 вся совокупность выражений (включая те, которые имеют значение ⊥) закрыт под Построение последовательности.
Семантика FP84 воплощена в базовой алгебре программ, наборе функциональный уровень равенства, которые можно использовать для манипулирования программами и рассуждений о них.
Смотрите также
Рекомендации
- ^ Концепция, развитие и применение языков функционального программирования В архиве 2016-03-11 в Wayback Machine Павел Худак, 1989 г.
- ^ а б c Бэкус, Дж. (1978). «Можно ли освободить программирование от стиля фон Неймана ?: Функциональный стиль и его алгебра программ». Коммуникации ACM. 21 (8): 613. Дои:10.1145/359576.359579.
- ^ Ян, Жан (2017). "Интервью с Саймоном Пейтон-Джонсом". Люди языков программирования.
- ^ Гаага, Джеймс (28 декабря 2007 г.). «Археология функционального программирования». Программирование в двадцать первом веке.
- Жертвуя простотой ради удобства: где провести черту?, Джон Х. Уильямс и Эдвард Л. Виммерс, Исследовательский центр IBM в Алмадене, Материалы пятнадцатого ежегодного симпозиума ACM SIGACT-SIGPLAN по принципам языков программирования, Сан-Диего, Калифорния, январь 1988 г.
внешняя ссылка
- Реализации FP
- Интерактивный FP (требуется Java), Страница помощи
- Интересные факты о FP (Немецкий)