WikiDer > SETL
Эта статья нужны дополнительные цитаты для проверка. (Апрель 2017 г.) (Узнайте, как и когда удалить этот шаблон сообщения) |
Парадигма | мультипарадигма: императив, процедурный, структурированный, объектно-ориентированный |
---|---|
Разработано | (Джек) Джейкоб Т. Шварц |
Разработчик | Курантский институт математических наук |
Впервые появился | 1969 |
Стабильный выпуск | 1.1 / 7 января 2005 г. |
Печатная дисциплина | Динамический |
Интернет сайт | Setl |
Под влиянием | |
АЛГОЛ 60 | |
Под влиянием | |
SETL2, ISETL, SETLX, ABC |
SETL (SET Language) - это язык программирования очень высокого уровня на основе математических теория множеств. Первоначально он был разработан (Джеком) Джейкоб Т. Шварц на Нью-Йоркский университет (Нью-Йоркский университет) Курантский институт математических наук в конце 1960-х гг.
Дизайн
SETL предоставляет два основных типа агрегированных данных: неупорядоченные наборы, и последовательности (последний также называется кортежи). Элементы наборов и кортежей могут быть любого произвольного типа, включая сами наборы и кортежи. Карты предоставляются в виде наборов пары (т. е. кортежи длиной 2) и могут иметь произвольные типы домена и диапазона. Примитивные операции в SETL включают, среди прочего, членство в множестве, объединение, пересечение и построение множества.
SETL предоставляет количественные логические выражения, построенные с использованием универсальный и экзистенциальные кванторы из логика предикатов первого порядка.
SETL предоставляет несколько итераторы для создания множества циклов по совокупным структурам данных.
Примеры
Выведите все простые числа от 2 до N:
print ([n в [2..N] | для всех m в {2..n - 1} | n mod m> 0]);
Обозначения аналогичны понимание списка.
Определение факториальной процедуры:
процедура factorial (n); - вычисляет факториал n! return if n = 1 then 1 else n * factorial (n - 1) end if; end факториал;
Более обычное выражение SETL для факториала (n> 0):
* / [1..n]
Использует
В 1970-х годах SETL был перенесен на БЭСМ-6, ES EVM и другие российские компьютерные системы.
SETL использовался для ранней реализации языка программирования Ада, названный переводчиком NYU Ada / ED.[1] Позже это стало первой проверенной реализацией Ada, сертифицированной 11 апреля 1983 года.[2]
В соответствии с Гвидо ван Россум, "Pythonпредшественник, ABC, был вдохновлен SETL - Ламберт Меертенс провел год с группой SETL в Нью-Йоркском университете, прежде чем придумать окончательный дизайн ABC! "[3]
Языковые варианты
УСТАНОВИТЬ язык 2 (SETL2), обратно несовместимый потомок SETL, был создан Кирком Снайдером из Института математических наук Куранта при Нью-Йоркском университете в конце 1980-х годов. Как и его предшественник, он основан на теории и обозначениях конечных множеств, но также на синтаксис и стиль языка Ада повлиял.
Интерактивный язык SET (ISETL) - вариант SETL, используемый в дискретная математика.
Рекомендации
- ^ Дьюар, Роберт Б. К .; Фишер-младший, Джеральд А.; Шенберг, Эдмонд; Froelich, Роберт; Брайант, Стивен; Госс, Клинтон Ф .; Берк, Майкл (ноябрь 1980). "Переводчик и устный переводчик Ada NYU". Уведомления ACM SIGPLAN - Материалы симпозиума ACM-SIGPLAN по языку программирования Ada. 15 (11): 194–201. Дои:10.1145/948632.948659. ISBN 0-89791-030-3.
- ^ SofTech Inc., Уолтем, Массачусетс (1983-04-11). "Сводный отчет о проверке компилятора Ada: NYU Ada / ED, версия 19.7 V-001". Получено 2010-12-16.CS1 maint: несколько имен: список авторов (связь)
- ^ Python-Dev: SETL (был: равнодушен к литералам диапазона)
дальнейшее чтение
- Шварц, Якоб Т. "Теория множеств как язык для спецификации программ и программирования". Курантский институт математических наук Нью-Йоркского университета, 1970.
- Шварц, Джейкоб Т., «О программировании, промежуточный отчет по проекту SETL», Департамент компьютерных наук, Институт математических наук Куранта, Нью-Йоркский университет (1973).
- Шварц, Якоб Т., Дьюар, Р. Б. К., Дубинский, Э., Шенберг, Э., Программирование с помощью наборов: введение в SETL, 1986. ISBN 0-387-96399-5.