~~~~~~~~~~~~~~~~~~~~ Arc.Ask3.Ru ~~~~~~~~~~~~~~~~~~~~~ 
Номер скриншота №:
✰ D56E04704916850E72B05B770AA8A5AC__1716603720 ✰
Заголовок документа оригинал.:
✰ Generalized algebraic data type - Wikipedia ✰
Заголовок документа перевод.:
✰ Обобщенный алгебраический тип данных — Википедия ✰
Снимок документа находящегося по адресу (URL):
✰ https://en.wikipedia.org/wiki/Generalized_algebraic_data_type ✰
Адрес хранения снимка оригинал (URL):
✰ https://arc.ask3.ru/arc/aa/d5/ac/d56e04704916850e72b05b770aa8a5ac.html ✰
Адрес хранения снимка перевод (URL):
✰ https://arc.ask3.ru/arc/aa/d5/ac/d56e04704916850e72b05b770aa8a5ac__translat.html ✰
Дата и время сохранения документа:
✰ 16.06.2024 09:37:54 (GMT+3, MSK) ✰
Дата и время изменения документа (по данным источника):
✰ 25 May 2024, at 05:22 (UTC). ✰ 

~~~~~~~~~~~~~~~~~~~~~~ Ask3.Ru ~~~~~~~~~~~~~~~~~~~~~~ 
Сервисы Ask3.ru: 
 Архив документов (Снимки документов, в формате HTML, PDF, PNG - подписанные ЭЦП, доказывающие существование документа в момент подписи. Перевод сохраненных документов на русский язык.)https://arc.ask3.ruОтветы на вопросы (Сервис ответов на вопросы, в основном, научной направленности)https://ask3.ru/answer2questionТоварный сопоставитель (Сервис сравнения и выбора товаров) ✰✰
✰ https://ask3.ru/product2collationПартнерыhttps://comrades.ask3.ru


Совет. Чтобы искать на странице, нажмите Ctrl+F или ⌘-F (для MacOS) и введите запрос в поле поиска.
Arc.Ask3.ru: далее начало оригинального документа

Обобщенный алгебраический тип данных — Википедия Jump to content

Обобщенный алгебраический тип данных

Из Википедии, бесплатной энциклопедии

В функциональном программировании обобщенный алгебраический тип данных ( GADT , также первоклассный фантомный тип , [1] защищенный рекурсивный тип данных , [2] или тип с указанием равенства [3] ) является обобщением параметрических алгебраических типов данных .

Обзор [ править ]

В GADT конструкторы продуктов (называемые конструкторами данных в Haskell ) могут обеспечить явное создание экземпляра ADT в качестве экземпляра типа возвращаемого значения. Это позволяет определять функции с более продвинутым типом поведения. Для конструктора данных Haskell 2010 возвращаемое значение имеет экземпляр типа, подразумеваемый созданием экземпляра параметров ADT в приложении конструктора.

-- Параметрический ADT, не являющийся 
 списком данных   GADT. List   a   =   Nil   |    Cons   a   (  List   a  ) 

 целые числа   ::   List   Int 
 целые числа   =   Cons   12   (  Cons   107   Nil  ) 

 строки   ::   List   String 
 strings   =   Cons   «boat»   (  Cons   «dock»   Nil  ) 

 GADT 
 — данные   Expr   a,   где 
     EBool    ::   Bool       ->   Expr   Bool 
     EInt     ::   Int        ->   Expr   Int 
     EEqual   ::   Expr   Int   ->   Expr   Int    ->   Expr   Bool 

 eval   ::   Expr   a   ->   a 
 eval   e   =   случай   e   из 
     EBool   a      ->   a 
     EInt   a       ->   a 
     EEqual   a   b   ->   (  eval   a  )   ==   (  eval   b  ) 

 expr1   ::   Expr   Bool 
 expr1   =   EEqual   (  EInt   2  )   (  EInt   3  ) 

 ret   =   eval   expr1   -- False 

В настоящее время они реализованы в компиляторе GHC как нестандартное расширение, используемое, в частности, Pugs и Darcs . OCaml изначально поддерживает GADT, начиная с версии 4.00. [4]

Реализация GHC обеспечивает поддержку параметров экзистенциального количественного типа и локальных ограничений.

История [ править ]

Ранняя версия обобщенных алгебраических типов данных была описана Augustsson & Petersson (1994) и основана на сопоставлении с образцом в ALF .

Обобщенные алгебраические типы данных были независимо представлены Чейни и Хинце (2003) , а ранее Си, Ченом и Ченом (2003) как расширения ML и Haskell алгебраических типов данных . [5] Оба по сути эквивалентны друг другу. Они подобны индуктивным семействам типов данных (или индуктивным типам данных ), найденным в Кока « Исчислении индуктивных конструкций» и других зависимо типизированных языках , по модулю зависимых типов и за исключением того, что последние имеют дополнительное ограничение положительности , которое не применяется в GADT. . [6]

Сульцманн, Вазни и Стаки (2006) представили расширенные алгебраические типы данных , которые объединяют GADT вместе с экзистенциальными типами данных и ограничениями классов типов .

Вывод типа в отсутствие каких-либо аннотаций типа , предоставленных программистом, неразрешим . [7] не допускают основных типов . и функции, определенные в GADT, вообще [8] Реконструкция типа требует нескольких конструктивных компромиссов и является областью активных исследований ( Пейтон Джонс, Уошберн и Вейрих, 2004 ; Пейтон Джонс и др., 2006) .

Весной 2021 года выйдет Scala 3.0. [9] В этом крупном обновлении Scala появилась возможность писать GADT. [10] с тем же синтаксисом, что и ADT , чего нет в других языках программирования, по мнению Мартина Одерски . [11]

Приложения [ править ]

Приложения GADT включают общее программирование , моделирование языков программирования ( абстрактный синтаксис высшего порядка ), поддержание инвариантов в структурах данных , выражение ограничений во встроенных предметно-ориентированных языках и моделирование объектов. [12]

Абстрактный синтаксис высшего порядка [ править ]

Важным применением GADT является встраивание абстрактного синтаксиса высшего порядка способом безопасным для типов . Вот встраивание просто типизированного лямбда-исчисления с произвольным набором базовых типов , кортежами и комбинатором с фиксированной точкой :

data   Lam   ::   *   ->   *   где 
   Lift   ::   a                       ->   Lam   a          -- ^ поднятое значение 
   Pair   ::   Lam   a   ->   Lam   b          ->   Lam   (  a  ,   b  )     -- ^ произведение 
   Lam    ::   (  Lam   a   - >   Lam   b  )        ->   Lam   (  a   ->   b  )   -- ^ лямбда-абстракция 
   App    ::   Lam   (  a   ->   b  )   ->   Lam   a   ->   Lam   b          -- ^ применение функции 
   Fix    ::   Lam   (  a   ->   a  )            ->   Lam   a          -- ^ фиксированная точка 

И типобезопасная функция оценки:

eval   ::   Lam   t   ->   t 
 eval   (  Lift   v  )     =   v 
 eval   (  Pair   l   r  )   =   (  eval   l  ,   eval   r  ) 
 eval   (  Lam   f  )      =   \  x   ->   eval   (  f   (  Lift   x  )) 
 eval   (  App   ж   x  )    =   (  eval   f  )   (  eval   x  ) 
 eval   (  Fix   f  )      =   (  eval   f  )   (  eval   (  Fix   f  )) 

Теперь функцию факториала можно записать так:

факт   =   Fix   (  Lam   (  \  f   ->   Lam   (  \  y   ->   Lift   (  если   eval   y   ==   0   , то   1   else   eval   y   *   (  eval   f  )   (  eval   y   -   1  ))))) 
 eval  (  факт  )(  10  ) 

Мы бы столкнулись с проблемами при использовании обычных алгебраических типов данных. Удаление параметра типа сделало бы поднятые базовые типы экзистенциально квантифицированными, что сделало бы невозможным написание оценщика. С параметром типа мы все равно будем ограничены одним базовым типом. Кроме того, неправильно сформированные выражения, такие как App (Lam (\x -> Lam (\y -> App x y))) (Lift True)можно было бы построить, хотя они имеют неправильный тип с использованием GADT. Правильно сформированный аналог App (Lam (\x -> Lam (\y -> App x y))) (Lift (\z -> True)). Это связано с тем, что тип x является Lam (a -> b), выведенный из типа Lam конструктор данных.

См. также [ править ]

Примечания [ править ]

  1. ^ Чейни и Хинце 2003 .
  2. ^ Си, Чен и Чен 2003 .
  3. ^ Шеард и Пашалич 2004 .
  4. ^ «ОКамл 4.00.1» . ocaml.org .
  5. ^ Чейни и Хинце 2003 , с. 25.
  6. ^ Чейни и Хинце 2003 , стр. 25–26.
  7. ^ Пейтон Джонс, Washburn & Weirich 2004 , стр. 7.
  8. ^ Шрийверс и др. 2009 , с. 1.
  9. ^ Кметюк, Анатолий. «SCALA 3 ЗДЕСЬ!🎉🎉🎉» . scala-lang.org . Федеральная политехническая школа Лозанны (EPFL), Лозанна, Швейцария . Проверено 19 мая 2021 г.
  10. ^ «SCALA 3 — КНИГА АЛГЕБРАИЧЕСКИХ ТИПОВ ДАННЫХ» . scala-lang.org . Федеральная политехническая школа Лозанны (EPFL), Лозанна, Швейцария . Проверено 19 мая 2021 г.
  11. ^ Одерский, Мартин. «Экскурсия по Scala 3 — Мартин Одерски» . youtube.com . Конференции Scala Days. Архивировано из оригинала 19 декабря 2021 г. Проверено 19 мая 2021 г.
  12. ^ Пейтон Джонс, Washburn & Weirich 2004 , стр. 3.

Дальнейшее чтение [ править ]

Приложения
Семантика
Тип реконструкции
Другой

Внешние ссылки [ править ]

Arc.Ask3.Ru: конец оригинального документа.
Arc.Ask3.Ru
Номер скриншота №: D56E04704916850E72B05B770AA8A5AC__1716603720
URL1:https://en.wikipedia.org/wiki/Generalized_algebraic_data_type
Заголовок, (Title) документа по адресу, URL1:
Generalized algebraic data type - Wikipedia
Данный printscreen веб страницы (снимок веб страницы, скриншот веб страницы), визуально-программная копия документа расположенного по адресу URL1 и сохраненная в файл, имеет: квалифицированную, усовершенствованную (подтверждены: метки времени, валидность сертификата), открепленную ЭЦП (приложена к данному файлу), что может быть использовано для подтверждения содержания и факта существования документа в этот момент времени. Права на данный скриншот принадлежат администрации Ask3.ru, использование в качестве доказательства только с письменного разрешения правообладателя скриншота. Администрация Ask3.ru не несет ответственности за информацию размещенную на данном скриншоте. Права на прочие зарегистрированные элементы любого права, изображенные на снимках принадлежат их владельцам. Качество перевода предоставляется как есть, любые претензии не могут быть предъявлены. Если вы не согласны с любым пунктом перечисленным выше, немедленно покиньте данный сайт. В случае нарушения любого пункта перечисленного выше, штраф 55! (Пятьдесят пять факториал, денежную единицу можете выбрать самостоятельно, выплаичвается товарами в течение 7 дней с момента нарушения.)