функцию нескольких аргументов, что она связывает? Если в нашей категории определено произведение объ-
ектов, то мы можем представить функцию двух аргументов, как стрелку, которая начинается из произведе-
ния:
(+) :
Но в лямбда-исчислении нам были доступны более гибкие функции, функции могли принимать на вход
функции и возвращать функции. Как с этим обстоят дела в теории категорий? Если перевести определение
функций высшего порядка на язык теории категорий, то мы получим стрелки, которые могут связывать дру-
гие стрелки. Категория с функциями высшего порядка может содержать свои стрелки в качестве объектов.
Стрелки как объекты обозначаются с помощью степени, так запись
нам необходимо уметь интерпретировать стрелку, мы хотим уметь подставлять значения. Если у нас есть
объект
На языке функций можно сказать, что стрелка
чение типа
определение.
Пусть в категории
этом следующая диаграмма коммутирует:
(
Давайте разберёмся, что это всё означает. По смыслу стрелка
аргументов. Вспомните о функции curry из Haskell. Диаграмма говорит о том, что если мы каррированием
функции двух аргументов получим функцию высшего порядка
получим значение, то это всё равно, что подставить два значения в исходную функцию. Запись (
означает параллельное применение двух стрелок внутри пары:
(
Так применив стрелки
Применение здесь условное мы подразумеваем применение в функциональной аналогии, в теории категорий
происходит связывание пар объектов с помощью стрелки (
Интересно, что и экспоненту можно получить как конечный объект в специальной категории. Пусть есть
категория
являются стрелки вида:
где
диаграмма коммутирует:
(
Если в этой категории существует конечный объект, то он является экспонентой. А функция
ется анаморфизмом для экспоненты.
238 | Глава 15: Теория категорий
15.9 Краткое содержание
Теория категорий изучает понятия через то как эти понятия взаимодействуют друг с другом. Мы забываем
о том, как эти понятия реализованы, а смотрим лишь на свойства связей.
Мы узнали что такое категория. Категория это структура с объектами и стрелками. Стрелки связывают
объекты. Причём связи могут соединятся. Также считается, что объект всегда связан сам с собой. Мы узнали,
что есть такие категории, в которых сами категории являются объектами, а стрелки в таких категориях мы
назвали функторами. Также мы узнали, что сами функторы могут стать объектами в некоторой категории,
тогда стрелки в этой категории мы будем называть естественными преобразованиями.
Мы узнали что такое начальный и конечный объект и как с помощью этих понятий можно определить
сумму и произведение типов. Также мы узнали как в теории категорий описываются функции высших по-
рядков.
15.10 Упражнения
• Проверьте аксиомы категории (ассоциативность и тождество) для категории функторов и категории
естественных преобразований.
• Изоморфизмом называют такие стрелки
Объекты
=
Докажите, что все начальные и конечные элементы изоморфны.
• Поскольку сумма и произведение типов являются начальным и конечным объектами в специальных
категориях для них также выполняются свойства тождества, уникальности и слияния. Выпишите эти
свойства для суммы и произведения.
• Подумайте как можно определить экземпляр класса Comonad для потоков:
data Stream a = a :& Stream a
Можно ли придумать экземпляр для класса Monad?
• Дуальную категорию для категории
то в исходной категории его называют
ра в
категории
Краткое содержание | 239