~~~~~~~~~~~~~~~~~~~~ Arc.Ask3.Ru ~~~~~~~~~~~~~~~~~~~~~ 
Номер скриншота №:
✰ B7AA7C61357A3548BC6328B4070EFCED__1700957220 ✰
Заголовок документа оригинал.:
✰ Parametricity - Wikipedia ✰
Заголовок документа перевод.:
✰ Параметричность — Википедия ✰
Снимок документа находящегося по адресу (URL):
✰ https://en.wikipedia.org/wiki/Parametricity ✰
Адрес хранения снимка оригинал (URL):
✰ https://arc.ask3.ru/arc/aa/b7/ed/b7aa7c61357a3548bc6328b4070efced.html ✰
Адрес хранения снимка перевод (URL):
✰ https://arc.ask3.ru/arc/aa/b7/ed/b7aa7c61357a3548bc6328b4070efced__translat.html ✰
Дата и время сохранения документа:
✰ 16.06.2024 18:57:02 (GMT+3, MSK) ✰
Дата и время изменения документа (по данным источника):
✰ 26 November 2023, at 03:07 (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

Параметричность

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

В теории языков программирования параметричность это абстрактное свойство единообразия, которым обладают параметрически полиморфные функции, которое отражает интуитивное представление о том, что все экземпляры полиморфной функции действуют одинаково.

Идея [ править ]

Рассмотрим этот пример, основанный на множестве X и типе T ( X ) = [ X X ] функций из X в себя. Функция высшего порядка дважды X : T ( X ) → T ( X ), заданная дважды X ( f ) = f f , интуитивно независима от множества X . Семейство всех таких функций дважды X , параметризованных множествами X , называется « параметрически полиморфной функцией ». Мы просто напишем дважды для всего семейства этих функций и запишем его тип как ИКС . Т ( Икс ) → Т ( Икс ). Отдельные функции дважды X называются компонентами или экземплярами полиморфной функции. Обратите внимание, что все функции-компоненты дважды X действуют «одинаково», потому что они заданы по одному и тому же правилу. Другие семейства функций, полученные выбором одной произвольной функции из каждого T ( X ) → T ( X ), не имели бы такой однородности. Их называют « специальными полиморфными функциями» . Параметричность — это абстрактное свойство, которым обладают равномерно действующие семейства, такие как дважды , что отличает их от специальных семейств. При адекватной формализации параметричности можно доказать, что параметрически полиморфные функции типа ИКС . T ( X ) → T ( X ) взаимно однозначны с натуральными числами. Функция, соответствующая натуральному числу n, задается правилом f ж н , т. е. полиморфное числительное Чёрча для n . Напротив, коллекция всех специальных семейств была бы слишком велика, чтобы представлять собой набор.

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

была Теорема параметричности первоначально сформулирована Джоном К. Рейнольдсом , который назвал ее теоремой абстракции . [1] В своей статье «Теоремы бесплатно!» [2] Филип Вадлер описал применение параметричности для вывода теорем о параметрически полиморфных функциях на основе их типов.

Реализация языка программирования [ править ]

Параметричность — основа многих программных преобразований , реализованных в компиляторах языка программирования Haskell . Эти преобразования традиционно считались правильными в Haskell из-за нестрогой семантики Haskell. Несмотря на то, что Haskell является ленивым языком программирования, он поддерживает некоторые примитивные операции, такие как оператор seq- которые включают так называемую «выборочную строгость», позволяющую программисту принудительно вычислить определенные выражения. В своей статье «Свободные теоремы при наличии seq » [3] Патрисия Йоханн и Янис Фойгтлендер показали, что из-за наличия этих операций общая теорема параметричности не справедлива для программ на Haskell; таким образом, эти преобразования в целом несостоятельны.

Зависимые типы [ править ]

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

Ссылки [ править ]

  1. ^ Рейнольдс, Дж. К. (1983). «Типы, абстракция и параметрический полиморфизм» (PDF) . Обработка информации . Северная Голландия, Амстердам. стр. 513–523.
  2. ^ Уодлер, Филип (сентябрь 1989 г.). "Теоремы бесплатно!" . 4-я Международная конференция. по функциональному программированию и архитектуре компьютеров . Лондон.
  3. ^ Иоганн, Патрисия; Янис Фойгтлендер (январь 2004 г.). «Свободные теоремы при наличии след . Учеб., Основы языков программирования . стр. 99–110. дои : 10.1145/964001.964010 .

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

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