MAD (язык программирования) - Википедия - MAD (programming language)

СУМАСШЕДШИЙ
ПарадигмаИмператив
РазработчикГаллер, Арден и Грэм
Впервые появился1959
Операционные системыUMES, МТС, CTSS, другие
Основной реализации
IBM 704, IBM 7090, UNIVAC 1108, Philco 210-211, IBM S / 360, и IBM S / 370
Диалекты
MAD, MAD / I, GOM
Под влиянием
IAL, АЛГОЛ 58

СУМАСШЕДШИЙ (Мичиганский алгоритм декодирования) это язык программирования и компилятор для IBM 704 а позже IBM 709, IBM 7090, IBM 7040, UNIVAC 1107, UNIVAC 1108, Philco 210-211, и в конечном итоге IBM S / 370 мэйнфрейм-компьютеры. Разработан в 1959 г. университет Мичигана к Бернард Галлер, Брюс Арден и Роберт М. Грэм, MAD - это вариант АЛГОЛ язык. Он широко использовался для обучения программированию в колледжах и университетах в 1960-х годах и сыграл незначительную роль в развитии CTSS, Мультики, а Терминальная система Мичигана компьютер операционные системы.[1]

Архивы в Историческая библиотека Bentley Университета Мичигана содержат справочные материалы по развитию MAD и MAD / I, в том числе распечатки трех погонных футов с рукописными пометками и оригинальные печатные руководства.[2][3][4][5]

MAD, MAD / I и GOM

Есть три компилятора MAD:

  1. Оригинал СУМАСШЕДШИЙ, компилятор, разработанный в 1959 году в Мичиганском университете для IBM 704 а позже IBM 709 и IBM 7090 мэйнфрейм компьютеры под управлением Исполнительная система Мичиганского университета (UMES) и Совместимая система разделения времени (CTSS) операционные системы.[6][7] В середине 1960-х годов MAD был перенесен на Университет Мэриленда к UNIVAC 1108.[8] Версии MAD также были доступны для Philco 210-211 и UNIVAC 1107.[8]
  2. MAD / I, «расширенная» версия MAD для IBM System / 360 серия компьютеров под управлением Терминальная система Мичигана (МТС). Работа над новым компилятором началась в 1965 году в рамках ARPA спонсировал проект CONCOMP в Мичиганском университете. По мере продвижения работы постепенно становилось ясно, что MAD / I был новым языком, независимым от исходной версии MAD 7090.[9]
  3. GOM (граммох Оld MН.э.), повторная реализация оригинального 7090 MAD для IBM System / 370 серии мэйнфреймов под управлением Терминальная система Мичигана (МТС). GOM был создан в начале 1980-х Доном Боттнером в вычислительном центре Мичиганского университета.[10][11]

История

Пока СУМАСШЕДШИЙ был мотивирован АЛГОЛ 58, он ни в чем не похож на АЛГОЛ 58.[12][13]

Программы, написанные на MAD, включали ПОЧТУ,[14] СТОК,[15] одна из первых систем обработки текста и несколько других утилит, находящихся под Совместимая система разделения времени (CTSS).[16] Была проведена работа над дизайном компилятора MAD для Мультики, но это так и не было реализовано.[17]

Ниже приводится интересная цитата из Интервью с Брайан Керниган[18] когда его спросили «Что вас зацепило программированием?»:

Я думаю, что больше всего мне нравилось программировать летом 1966 года, когда я работал в Project MAC в Массачусетском технологическом институте, где я работал над программой, которая создавала рабочую ленту для нового GE 645 в первые дни существования Multics. Я писал в MAD, что было намного проще и приятнее, чем FORTRAN и COBOL, которые я написал ранее, и я использовал CTSS, первую систему разделения времени, которая была бесконечно проще и приятнее, чем перфокарты.

MAD был довольно быстрым по сравнению с некоторыми другими компиляторами того времени. Поскольку ряд людей были заинтересованы в использовании FORTRAN язык и все же хотел получить скорость компилятора MAD, была разработана система под названием MADTRAN (написанная на MAD). MADTRAN был просто переводчиком с FORTRAN на MAD, который затем производил машинный код. MADTRAN распространялся через ПОДЕЛИТЬСЯ.[12]

MAD / I имеет синтаксическую структуру, аналогичную АЛГОЛ 60 вместе с важными особенностями оригинального MAD и от PL / I.[9] MAD / I был разработан как расширяемый язык. Он был доступен для использования под МТС и предоставил много новых идей, которые проникли в другие языки, но компиляция MAD / I была медленной, и MAD / I никогда не распространился на широкое использование по сравнению с исходным 7090 MAD.[11]

GOM По сути, это язык 7090 MAD, модифицированный и расширенный для архитектуры 360/370 с некоторой разумной адаптацией, чтобы лучше соответствовать текущим методам программирования и задачам.[11] В МТС Система сообщений была написана на GOM.

MAD, журнал MAD и Альфред Э. Нойман

Вывод на строчный принтер после ошибки компилятора MAD на компьютере IBM 704 в Мичиганском университете, c. 1960 г.

В предварительной версии оригинального MAD, в качестве ссылки на тезку MAD, Журнал MAD, когда программа содержала слишком много ошибок во время компиляции, компилятор печатал изображение на всю страницу Альфред Э. Нойман с помощью ASCII искусство. Подпись гласила: «Посмотрите на этого человека о своей программе - он может захотеть опубликовать ее. Он никогда не беспокоится - но, судя по виду вашей программы, вам следует».[8] Эта функция не была включена в окончательную официальную версию.[19] Однако он был включен в производственную версию для IBM 7040.

А Берни Галлер вспоминает:

К тому времени, когда мы разработали язык, который, как мы думали, стоит делать и для которого мы могли бы сделать компилятор, мы уже не могли называть его Algol; это действительно было иначе. Именно тогда мы приняли название MAD от Michigan Algorithm Decoder. У нас было забавное общение с людьми из Mad Magazine, когда мы попросили разрешения использовать имя MAD. В очень забавном письме они сказали нам, что подадут на нас в суд и все остальное, но закончили угрозу P.S. внизу - «Конечно, продолжай». К сожалению, это письмо потеряно.[20]

Пример "Привет, мир"

"Привет, мир "пример программы выводит строку" Hello, world "на терминал или экран.

ФОРМАТ ПЕЧАТИ HELLOWVECTOR ЗНАЧЕНИЯ ПРИВЕТ = 13ч0 $ Привет, мир * $ КОНЕЦ ПРОГРАММЫ

Первый символ строки рассматривается как логическое управление кареткой, в этом примере символ «0», который вызывает печать строки с двойным интервалом.

В качестве альтернативы можно использовать сокращения, и компилятор расширит их в листинге:

P'T HELLOWV'S HELLOW = $ 13h0Hello, world * $ E'M

Элементы языка

MAD и GOM, но не MAD / I, состоят из следующих элементов:[7][11][12]

Формат ввода

Программы MAD представляют собой серию утверждений, записанных на перфокартах, обычно по одному утверждению на карту, хотя утверждение может быть продолжено для нескольких карт. Столбцы 1-10 содержат необязательную метку оператора, комментарии или примечания помечаются буквой «R» в столбце 11, а столбцы 73-80 не используются и могут содержать идентификатор последовательности. Пробелы не имеют значения, кроме как внутри символьных констант. Для GOM ввод - произвольная форма без поля последовательности, и строки могут быть длиной до 255 символов; строки, начинающиеся со звездочки (*), являются комментариями; а строки, начинающиеся со знака плюс (+), являются линиями продолжения.

Имена

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

Некоторые ключевые слова в языке являются зарезервированными, поскольку большинство из них длиннее шести букв или окружены точками. Существует стандартный набор сокращений, которые можно использовать для замены более длинных слов. Они состоят из первой и последней букв ключевых слов с апострофом между ними, например W'R для WHENEVER и D'N для DIMENSION.

Типы данных

MAD использует термин «режим» для своих типов данных. Поддерживаются пять основных режимов:

  • Целое число записывается с масштабным коэффициентом или без него (1, +1, -1, 1K10, 1K) или в виде восьмеричных констант (до 7777777777777K);
  • Плавающая точка записывается с показателем степени или без него (0., 1.5, -0.05, +100.4, -4., .05E-2, -.05E2, 5E02, 5.E2);
  • Булево (1B для истины и 0B для false);
  • Этикетка с заявлением, и
  • Название функции записывается как имя, за которым следует точка (SQRT.).

Режим константы можно переопределить, добавив символ M, за которым следует одна цифра в конце константы, где 0 указывает на плавающую точку, 1 целое число, 2 логических значения, 3 имени функции и 4 метки оператора.

Для GOM добавлены шесть дополнительных режимов: CHARACTER, SHORT INTEGER, BYTE INTEGER, LONG INTEGER, POINTER и DYNAMIC RECORD.

Буквенные или символьные константы хранятся в виде целых чисел и записываются с использованием знака доллара в качестве разделителя ($ ABCDEF $) с двойными знаками доллара, используемыми для ввода истинного знака доллара ($$$. 56 $ - 56 центов). Строки длиной более шести символов представлены с помощью массивов.

Массивы и матрицы

  • Нет ограничений по количеству размеров.
  • Допускаются отрицательные и нулевые индексы, а также индексы с плавающей запятой.
  • Матрицы хранятся в последовательных ячейках памяти в порядке, определяемом первым изменением самого правого нижнего индекса.
  • На матрицы можно ссылаться с помощью нижнего индекса для каждого измерения NAME (s1, с2, с3) или с помощью одного нижнего индекса ИМЯ (s1).
  • Списки ввода-вывода, операторы VECTOR VALUES и некоторые подпрограммы позволяют использовать блочную нотацию, которая имеет форму A, ..., B или A ... B, которая является ссылкой на всю область от A до B. включительно. В терминах вектора A (1) ... A (N) будет A (1), A (2), A (3), ..., A (N).
  • Есть средства, позволяющие изменять размеры во время работы; разрешение программисту изменять положение начального элемента в массиве внутри всего блока, который был выделен для массива; и позволяет указать произвольное отображение хранилища.
Список операторов, операторов и функций

Операторы

Заявления декларации

Переменные могут быть объявлены явно или неявно. По умолчанию предполагается, что все неявно объявленные переменные являются плавающими. Для изменения этого значения по умолчанию можно использовать оператор NORMAL MODE IS.

Исполняемые операторы

Операторы ввода и вывода

Функции

Имена функций заканчиваются точкой. Поддерживаются внутренние и внешние функции. Внутренние функции компилируются как часть программы, в которой они используются, и разделяют объявления и переменные с основной программой. Внешние функции компилируются отдельно и не имеют общих объявлений и переменных. Допускается определение внутренних функций одним оператором. Рекурсивные функции разрешены, хотя функция должна сама выполнять некоторые необходимые операции по сохранению и восстановлению.

Определение и переопределение оператора

Одной из наиболее интересных функций MAD ​​является возможность расширения языка путем переопределения существующих операторов, определения новых операторов или определения новых типов данных (режимов). Определения сделаны с использованием операторов объявления MAD и мнемоники языка ассемблера, включенной после объявления до псевдо-инструкции END, реализующей операцию.

  • ОПРЕДЕЛЕНИЕ БИНАРНОГО ОПЕРАТОРА определенная операция, ПРЕДИСЛОВИЕ классифицировать существующая операция СТРУКТУРА РЕЖИМА параметры режима
  • ОПРЕДЕЛЕНИЕ УНАРНОГО ОПЕРАТОРА определенная операция, ПРЕДИСЛОВИЕ классифицировать существующая операция СТРУКТУРА РЕЖИМА параметры режима
  • СТРУКТУРА РЕЖИМА режим-нет = режим-нет существующая операция режим-нет
  • СТРУКТУРА РЕЖИМА режим-нет = режим-нет существующая операция режим-нет ТАКАЯ ПОСЛЕДОВАТЕЛЬНОСТЬ, КАК режим-нет существующая операция режим-нет

куда:

  • классифицировать является одним из ТАК КАК, НИЖЕ или ВЫШЕ; и
  • параметры режима - это параметры, которые появляются в операторе MODE STRUCTURE.

Три предопределенных пакета определений (MATRIX, DOUBLE PRECISION и COMPLEX) доступны для включения в исходные программы MAD с помощью оператора INCLUDE.

  • ВКЛЮЧАЮТ упаковка

Смотрите также

Примечания

  1. ^ Альт, Франц (1967). Достижения в области компьютеров. Академическая пресса. п. 143. ISBN  0-12-012104-2.
  2. ^ Технические заметки, Публикации вычислительного центра Мичиганского университета, 1965–1999 гг.
  3. ^ Технические отчеты, Публикации вычислительного центра Мичиганского университета, 1965–1999 гг.
  4. ^ Актуальный файл 1960-1986, Отчеты вычислительного центра Мичиганского университета, 1952–1996 гг.
  5. ^ MAD (Мичиганский алгоритм декодирования) 1960-1979 гг., Отчеты вычислительного центра Мичиганского университета, 1952–1996 гг.
  6. ^ Справочное руководство пользователя Michigan Algorithm Decoder (MAD) для IBM 7090, Лаборатория цифровых компьютеров, Высший колледж Иллинойского университета, 1962 г., 221 страница.
  7. ^ а б Декодер алгоритмов Мичигана (Руководство MAD), Брюс В. Арден, переработанное издание 1966 г.
  8. ^ а б c Джордж Грей (июнь 2002 г.). «УНИВАК и АЛГОЛ». Информационный бюллетень Unisys History. 6 (2). Архивировано из оригинал 29 июня 2017 г.
  9. ^ а б Руководство MAD / I, Болас, Спрингер и Сродава, Технический отчет CONCOMP 32, 1970, Мичиганский университет, Анн-Арбор, 194 страницы.
  10. ^ MTS Volume 2: Описание общедоступных файлов, Вычислительный центр Мичиганского университета, 1990, стр. 14
  11. ^ а б c d GOM Руководство, Дон Бёттнер, Вычислительный центр Мичиганского университета, Анн-Арбор, июнь 1989 г.
  12. ^ а б c Компьютерные языки - принципы и история В архиве 2011-06-07 на Wayback Machine, Sammet, Jean E., Englewood Cliffs, N.J., Prentice-Hall 1969, p. 205
  13. ^ В августе 2010 года, когда его спросили о заявлении Джин Саммет о том, что «MAD не похож на АЛГОЛ 58 каким-либо существенным образом», Брюс Арден написал: «Что касается Джин Саммет, она, возможно, объединила две версии IAL (58 и 60 ). В отличие от более поздней версии, версия 58 ничего не говорила о том, какие слова (или язык) следует использовать для идентификации условных операторов и операторов передачи, что привело к синтаксическому анализу таких слов, как WHENEVER. Также в MAD были некоторые дополнительные функции, выходящие за рамки 58 спецификаций ».
  14. ^ Документация и исходный код для ранней электронной почты и обмена сообщениями, Том Ван Флек
  15. ^ "... Дуг Макилрой и Боб Моррис написали сток Multics в BCPL на основе MAD-версии RUNOFF для CTSS Джерри Зальцера.", «Функции программного обеспечения Multics: раздел 1.7.7», Веб-сайт Multicans. Проверено 10 ноября 2018.
  16. ^ Совместимая система с разделением времени (1961-1973): обзор памятной даты пятидесятилетия, Дэвид Уолден и Том Ван Флек (редакторы), 2011 г., IEEE Computer Society. Проверено 10 ноября 2018.
  17. ^ «Глоссарий аббревиатур и терминов Multics», Том Ван Влек, веб-сайт Multicans.
  18. ^ Интервью с Брайаном Керниганом: разведение малых языков, Аллен Норен, 2009
  19. ^ Шнейдерман, Бен; Плезант, Екатерина (2004-05-07). Разработка пользовательского интерфейса (4-е изд.). Эддисон Уэсли. ISBN  978-0-321-19786-3.
  20. ^ Бернард А. Галлер; Энид Х. Галлер (январь 2001 г.). «Карьерное интервью с Берни Галлером». IEEE Annals of the History of Computing. 23 (1): 22–33. Дои:10.1109/85.910847. ISSN  1058-6180.

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

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