• A
  • A
  • A
  • АБB
  • АБB
  • АБB
  • А
  • А
  • А
  • А
  • А
Обычная версия сайта
Бакалавриат 2025/2026

Типы в языках программирования

Когда читается: 3-й курс, 1, 2 модуль
Охват аудитории: для своего кампуса
Преподаватели: Соколов Павел Павлович
Язык: русский
Кредиты: 5
Контактные часы: 56

Программа дисциплины

Аннотация

Можно с уверенностью сказать, что сфера разработки языков программирования переживает новый бум — из тех имён, что на слуху, можно назвать Rust, Julia, Kotlin, Crystal, Zig,.. Причём основным selling point большинства новых языков является какая-то инновационная система типов. Данный курс как раз и посвящен введению в теорию типов — учение о дизайне систем типов и разработке соответствующих алгоритмов. Будем решать как теоретические, так и практические задачи; если вам до этого нравились курсы по дискретной математике, логике, вычислимости и алгоритмам, вам понравится и здесь.
Цель освоения дисциплины

Цель освоения дисциплины

  • изучение основных алгоритмов проверки и вывода типов
  • знакомство с взаимосвязями между теорией типов и логикой, написанием кода и доказательством теорем
Планируемые результаты обучения

Планируемые результаты обучения

  • знакомство с теорией типов
  • умение формализовать системы типов различных языков программирования
Содержание учебной дисциплины

Содержание учебной дисциплины

  • Введение в теорию типов. Система типов и денотационная семантика языка арифметики.
  • Арифметика с объявлениями. Подстановки и замыкания. Preservation и progress теоремы.
  • Лямбда-исчисление: определение, операционная семантика, конфлюэнтность.
  • Алгебраические типы данных и тип функций.
  • Категорная семантика. Операторы на типах.
  • Полиморфизм и System F. Параметричность. Лямбда-куб.
  • Система типов Хиндли-Милнера. Декларативные правила вывода.
  • Отношение подтипизации. Ко- и контравариантность.
  • Логическое программирование, классы типов и их взаимосвязь.
  • Рекурсивные типы данных и их денотационная семантика.
  • Программа как доказательство. Пруверы. Зависимые типы.
  • Полиморфизм в DTT. Парадокс Жирара. Вселенные.
  • Роль равенства в зависимых типах. Гомотопическая теория типов.
  • Субструктурные логики и системы типов. Утверждения как сессии.
Элементы контроля

Элементы контроля

  • неблокирующий Теоретическое домашнее задание 1
    Формулировка и доказательство здравости для системы IntBool с объявлениями.
  • неблокирующий Теоретическое домашнее задание 2
    Доказательство Тьюринг-полноты нетипизированного лямбда-исчисления.
  • неблокирующий Теоретическое домашнее задание 3
    Доказательство несложных утверждений в STLC.
  • неблокирующий Практическое домашнее задание 1
    Реализация парсера и форматировщика учебного языка программирования.
  • неблокирующий Практическое домашнее задание 2
    Реализация алгоритма W с различными расширениями. Базовая реализация 10б, расширения – до 0.25 бонусных баллов.
  • неблокирующий Бонусное теоретическое домашнее задание
    Исследование свойств системы типов со строковым полиморфизмом. До 0.5 бонусных баллов.
  • неблокирующий Практическое домашнее задание 3
    Реализация двусторонней проверки типов с различными расширениями. Также можно получить до 0.25 бб.
  • неблокирующий Бонусное практическое домашнее задание
    Доказательство (с устной защитой) коммутативности сложения в Twelf. До 0.5 бонусных баллов.
  • неблокирующий Практическое домашнее задание 4
    Доказательство утверждений в Arend.
  • неблокирующий Экзамен
    Доказательство утверждений в Arend.
Промежуточная аттестация

Промежуточная аттестация

  • 2025/2026 2nd module
    Итог = Округление(0.4 * ТДЗ + 0.4 * ПДЗ + 0.2 * Э + Б), где ТДЗ – средняя оценка за теоретические домашние задания, ПДЗ – за практические, Э – оценка за экзамен, а Б – сумма полученных за курс бонусов.
Список литературы

Список литературы

Рекомендуемая основная литература

  • Pierce, B. C. (2005). Advanced Topics in Types and Programming Languages. Cambridge, Mass: The MIT Press. Retrieved from http://search.ebscohost.com/login.aspx?direct=true&site=eds-live&db=edsebk&AN=138471
  • Sørensen, M. H., & Urzyczyn, P. (2006). Lectures on the Curry-Howard Isomorphism (Vol. 1st ed). Amsterdam: Elsevier Science. Retrieved from http://search.ebscohost.com/login.aspx?direct=true&site=eds-live&db=edsebk&AN=196231

Рекомендуемая дополнительная литература

  • Pierce, B. C. (2002). Types and Programming Languages. Cambridge, Mass: The MIT Press. Retrieved from http://search.ebscohost.com/login.aspx?direct=true&site=eds-live&db=edsebk&AN=70966

Авторы

  • Кононова Елизавета Дмитриевна