Jump to content

Исчисление шаблонов

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

пусть   записи   размер   =    |   x   y   ->   (  размер   x  )   +   (  размер   y  )    |   х   ->   1 

Второй, или случай по умолчанию x -> 1 соответствует шаблону xпротив аргумента и возвращает 1. Этотcase используется только в том случае, если сопоставление не удалось в первом случае.первое или особое совпадение с любым соединением , напримеркак непустой список или пару. Соответствующие привязки x к левому компонентуи y к нужному компоненту. Затем в тело корпуса добавляетсяразмеры этих компонентов вместе взятые.

Подобные методы позволяют получить общие запросы для поиска и обновления. Такое объединение рекурсии и декомпозиции дает полиморфизм путей .

Возможность передачи шаблонов в качестве параметров ( полиморфизм шаблонов ) иллюстрируется определением универсальный элиминатор. Предположим, что заданы конструкторы Leaf для созданиялистья дерева и Count для преобразования чисел всчетчики. Тогда соответствующие элиминаторы

элимлист    =   |    Лист   y   ->   y   elimCount   =   |   Посчитайте   y   ->   y 

Например, elimLeaf (Leaf 3) оценивается как 3 как и elimCount (Count 3).

Эти примеры можно получить, применив общий элиминатор elim рассматриваемым конструкторам. Это определяется

элим   =   |   х   ->   |   {  y  }   х   y   ->   y 

Сейчас elim Leaf оценивается как | {y} Leaf y -> y что эквивалентно elimLeaf. Также elim Count эквивалентно elimCount.

В общем, фигурные скобки {} содержат связанные переменныеузор, так что x бесплатно и y связан в | {y} x y -> y.

[ редактировать ]
  • Архивное зеркало ссылок ниже (которых больше нет в сети)
  • Джей, К. Барри (ноябрь 2004 г.). «Узорное исчисление» . АКМ Транс. Программа. Ланг. Сист . 26 (6): 911–937. дои : 10.1145/1034774.1034775 . S2CID   14252624 . — оригинальная статья, но не самая общая.
  • Джей, Б.; Кеснер, Д. (2006). «Чистое шаблонное исчисление». В Сестофте, П. (ред.). Языки и системы программирования. ЭСОП 2006 . Конспекты лекций по информатике. Том. 3924. Спрингер. стр. 100–114. дои : 10.1007/11693024_8 . hdl : 10453/1684 . ISBN  978-3-540-33096-7 .
  • Джей, Барри (2009). Шаблонное исчисление: вычисления с помощью функций и структур . Спрингер. дои : 10.1007/978-3-540-89185-7 . ISBN  978-3-540-89185-7 .
  • сайт исследования языка программирования Bondi
  • Гивен-Уилсон, Т.; Горла, Д.; Джей, Б. (2010). «Исчисление параллельных шаблонов». В Калуде, CS; Сассоне, В. (ред.). Теоретическая информатика. ТКС 2010 . ИФИП: Достижения в области информационных и коммуникационных технологий. Том. 323. Спрингер. дои : 10.1007/978-3-642-15240-5_18 . ISBN  978-3-642-15240-5 .
Arc.Ask3.Ru: конец переведенного документа.
Arc.Ask3.Ru
Номер скриншота №: f447ac730591ed2670d0715c368d006c__1675092000
URL1:https://arc.ask3.ru/arc/aa/f4/6c/f447ac730591ed2670d0715c368d006c.html
Заголовок, (Title) документа по адресу, URL1:
Pattern calculus - Wikipedia
Данный printscreen веб страницы (снимок веб страницы, скриншот веб страницы), визуально-программная копия документа расположенного по адресу URL1 и сохраненная в файл, имеет: квалифицированную, усовершенствованную (подтверждены: метки времени, валидность сертификата), открепленную ЭЦП (приложена к данному файлу), что может быть использовано для подтверждения содержания и факта существования документа в этот момент времени. Права на данный скриншот принадлежат администрации Ask3.ru, использование в качестве доказательства только с письменного разрешения правообладателя скриншота. Администрация Ask3.ru не несет ответственности за информацию размещенную на данном скриншоте. Права на прочие зарегистрированные элементы любого права, изображенные на снимках принадлежат их владельцам. Качество перевода предоставляется как есть. Любые претензии, иски не могут быть предъявлены. Если вы не согласны с любым пунктом перечисленным выше, вы не можете использовать данный сайт и информация размещенную на нем (сайте/странице), немедленно покиньте данный сайт. В случае нарушения любого пункта перечисленного выше, штраф 55! (Пятьдесят пять факториал, Денежную единицу (имеющую самостоятельную стоимость) можете выбрать самостоятельно, выплаичвается товарами в течение 7 дней с момента нарушения.)