Мы используем файлы cookies для улучшения работы сайта НИУ ВШЭ и большего удобства его использования. Более подробную информацию об использовании файлов cookies можно найти здесь, наши правила обработки персональных данных – здесь. Продолжая пользоваться сайтом, вы подтверждаете, что были проинформированы об использовании файлов cookies сайтом НИУ ВШЭ и согласны с нашими правилами обработки персональных данных. Вы можете отключить файлы cookies в настройках Вашего браузера.

  • A
  • A
  • A
  • АБВ
  • АБВ
  • АБВ
  • А
  • А
  • А
  • А
  • А
Обычная версия сайта
13
Апрель

Функциональное программирование

2024/2025
Учебный год
RUS
Обучение ведется на русском языке
3
Кредиты

Преподаватель

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

Аннотация

Настоящая дисциплина относится к профессиональному циклу, дисциплинам базовой части профиля. Для специализации «Распределенные системы» настоящая дисциплина является базовой. Изучение данной дисциплины базируется на знании курса “Сложность вычислений и логика в теоретической информатике”.
Цель освоения дисциплины

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

  • Освоение теоретической базы функционального программирования (начала теории типов, лямбда-исчисление, начала теории категорий).
  • Овладение техникой программирования на языке Haskell.
Планируемые результаты обучения

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

  • Студент владеет общей информацией об императивном и функциональном стилях программирования, их сильных и слабых сторонах, умеет выбирать правильный стиль в зависимости от задачи.
  • Студент знает теоретические основы функционального программирования (лямбда-исчисление, начала теории категорий и проч.).
  • Студент разрабатывает новые библиотеки на языке Haskell.
  • Студент решает задачи на программирование на языке Haskell.
  • Студент создает код на функциональном языке, корректность которого формально доказана (верифицирована).
Содержание учебной дисциплины

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

  • Типизованное лямбда-исчисление
  • Нормализуемость и конфлюэнтность
  • Императивное и функциональное программирование. Элементы функционального программирования в императивных языках
  • Язык и среда разработки Haskell: установка и настройка
  • Основы программирования на языке Haskell
  • Типы данных в Haskell
  • "Ленивые" и "ретивые" вычисления
  • Монады и их использование для ввода-вывода
  • Соответствие Карри - Говарда. Верификация программ и математических утверждений. Система Coq
Элементы контроля

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

  • неблокирующий тест
    Тест состоит из 5 вопросов со множественным выбором ответа, за каждый вопрос начисляется 2 балла
  • неблокирующий Домашнее задание
    Развернутый ответ на вопрос
Промежуточная аттестация

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

  • 2024/2025 3rd module
    0.3 * Домашнее задание + 0.7 * тест
Список литературы

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

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

  • Barendregt, H., Dekkers, W., Statman, R. Lambda calculus with types. – Cambridge University Press, 2013. – 856 pp.

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

  • Lipovaca M. Learn you a Haskell for great good!: a beginner's guide. – No Starch Press, 2011. – 404 pp.

Авторы

  • Кузнецов Степан Львович