Jump to content

Эшер (язык программирования)

Эшер
Парадигма декларативный : функциональный , логический
Разработано Дж. В. Ллойд
Впервые появился один-1990-е
Дисциплина набора текста статический , манифест
Основные реализации
Реализация Ки Сионг Нг
Под влиянием
простая теория типов

Escher (названный в честь М. К. Эшера , «мастера бесконечных циклов») — это язык декларативного программирования , поддерживающий модели функционального и логического программирования , разработанный Дж. У. Ллойдом в середине 1990-х годов. Он был разработан в основном как исследовательский и обучающий инструмент. Основной взгляд на программирование, представленный Эшером и родственными языками, заключается в том, что программа — это представление теории в некоторой логической структуре , а выполнение программы (вычисление) — это вывод из теории. Логической основой Эшера является Алонзо Чёрча простая теория типов .

Эшер, в частности, поддерживает ввод-вывод через монадический тип, представляющий «внешний мир», в стиле Haskell . Одной из целей разработчиков Эшера была поддержка метапрограммирования , поэтому язык имеет комплексную поддержку генерации и преобразования программ.

MODULE      Lambda.
CONSTRUCT   Person/0.
FUNCTION    Jane, Mary, John: One -> Person.

FUNCTION    Mother : Person * Person -> Boolean.
Mother(x,y) =>
    x=Jane & y=Mary.

FUNCTION    Wife : Person * Person -> Boolean.
Wife(x,y) =>
    x=John & y=Jane.

FUNCTION    PrimitiveRel : (Person * Person -> Boolean) -> Boolean.
PrimitiveRel(r) =>
    r=Mother \/ r=Wife.

FUNCTION    Rel : (Person * Person -> Boolean) -> Boolean.
Rel(r) =>
    PrimitiveRel(r) \/
    (SOME [r1,r2]
        (r = LAMBDA [u] (SOME [z] (r1(Fst(u),z) & r2(z,Snd(u)))) &
            PrimitiveRel(r1) & PrimitiveRel(r2))).
Arc.Ask3.Ru: конец переведенного документа.
Arc.Ask3.Ru
Номер скриншота №: 2394ea6478d48c89e2332c0ffa30770a__1696321980
URL1:https://arc.ask3.ru/arc/aa/23/0a/2394ea6478d48c89e2332c0ffa30770a.html
Заголовок, (Title) документа по адресу, URL1:
Escher (programming language) - Wikipedia
Данный printscreen веб страницы (снимок веб страницы, скриншот веб страницы), визуально-программная копия документа расположенного по адресу URL1 и сохраненная в файл, имеет: квалифицированную, усовершенствованную (подтверждены: метки времени, валидность сертификата), открепленную ЭЦП (приложена к данному файлу), что может быть использовано для подтверждения содержания и факта существования документа в этот момент времени. Права на данный скриншот принадлежат администрации Ask3.ru, использование в качестве доказательства только с письменного разрешения правообладателя скриншота. Администрация Ask3.ru не несет ответственности за информацию размещенную на данном скриншоте. Права на прочие зарегистрированные элементы любого права, изображенные на снимках принадлежат их владельцам. Качество перевода предоставляется как есть. Любые претензии, иски не могут быть предъявлены. Если вы не согласны с любым пунктом перечисленным выше, вы не можете использовать данный сайт и информация размещенную на нем (сайте/странице), немедленно покиньте данный сайт. В случае нарушения любого пункта перечисленного выше, штраф 55! (Пятьдесят пять факториал, Денежную единицу (имеющую самостоятельную стоимость) можете выбрать самостоятельно, выплаичвается товарами в течение 7 дней с момента нарушения.)