Методические рекомендации для студентов по изучению курса «Функциональное программирование»
Методические рекомендации по изучению теоретического материала
Данный курс предусматривает изучение теоретических вопросов, в соответствии с рабочей программой, а также выполнение лабораторных и семестровых работ.
В теоретической части курса изучаются теоретические основы функционального программирования, функциональный подход к программированию на примере языка программирования Лисп; а также рассматривается реализация ряда прикладных задач на Лиспе.
В практической части курса изучаются основы функционального языка программирования Лисп, рекурсивные алгоритмы и реализация их на Лиспе.
По окончании курса студент должен знать основы языка Лисп, уметь реализовывать рекурсивные алгоритмы на Лиспе, а также решать прикладные задачи нечислового программирования, предусмотренные программой курса, на Лиспе.
Для изучения теоретической части курса необходимо изучить вопросы, рассматриваемые в лекциях. При изучении материала необходимо помимо лекционных материалов использовать рекомендуемую литературу для лучшего усвоения материала.
Методические рекомендации по выполнению лабораторных работ
Лабораторная работа 1. Базовые функции
Цель работы: научиться работать в интерпретаторе Common Lisp, познакомиться с базовыми предикатами работы со списками.
Для выполнения лабораторной работы необходимо:
1. Изучить учебные материалы, представленные в презентации лабораторного практикума. При изучении материала необходимо повторить все представленные в презентации примеры.
2. Выполнить задания в конце презентации лабораторного практикума.
В результате выполнения лабораторной работы студент должен научиться работать с интерпретатором Common Lisp, научиться работать с базовыми предикатами разбора и построения списков, а также предикатами определения типа аргумента.
На изучение данной темы отводится 2 часа.
Лабораторная работа 2. Имя и значение символа, свойства символа
Цель работы: изучить понятия переменной и константы, формы quote, set, setq, eval, а также свойства символа, научиться задавать и изменять свойства.
Для выполнения лабораторной работы необходимо:
1. Изучить учебные материалы, представленные в презентациях лабораторных практикумов. При изучении материала необходимо повторить все представленные в презентациях примеры.
2. Выполнить задания в конце презентаций лабораторного практикума.
В результате выполнения лабораторной работы студент должен научиться назначать переменной значение, а также определять ее свойства, использовать формы quote и eval для приостановления и запуска вычислений.
На выполнение лабораторной работы предусмотрено 2 часа.
Лабораторная работа 3. Определение функции, передача параметров и область их действия. Внутреннее представление списков.
Цель занятия: изучение формы для определения функций, понятий вычислительного окружения или контекста, статической, глобальной и динамической переменной.
Для выполнения лабораторной работы необходимо:
1. Изучить учебные материалы, представленные в презентациях лабораторных практикумов. При изучении материала необходимо повторить все представленные в презентациях примеры.
2. Выполнить задания в конце презентаций лабораторного практикума.
В результате выполнения лабораторной работы студент должен научиться описывать функции и различать типы переменных в зависимости от контекста.
На выполнение лабораторной работы предусмотрено 2 часа.
Лабораторная работа 4. Вычисления в Лиспе.
Цель занятия: рассмотреть классификацию лисповских форм, изучить основные лисповские формы.
Порядок выполнения работы:
1. Изучить учебные материалы, представленные в презентации лабораторных практикумов. При изучении материала необходимо повторить все представленные в презентациях примеры.
2. Выполнить задания в конце презентаций лабораторного практикума.
В результате выполнения данной работы студенты должны познакомиться и научиться использовать лисповские формы, представленные в презентации, для вычислений в Лиспе.
На выполнение лабораторной работы предусмотрено 2 часа.
Лабораторная работа 5. Внутреннее представление списков. Основы рекурсии.
Цель работы: изучить понятие списочной ячейки, а также внутреннее представление списков, понятие простой рекурсии, изучить принципы построения рекурсивных алгоритмов, изучить рекурсивные функции обработки списков.
Порядок выполнения работы:
1. Изучить учебные материалы, представленные в презентациях лабораторных практикумов. При изучении материала необходимо повторить все представленные в презентациях примеры.
2. Выполнить задания в конце презентаций лабораторного практикума.
В результате выполнения данной работы студенты должны получить представление о внутренней структуре списков, научиться использовать простую рекурсия для построения функций для работы со списками.
На выполнение лабораторной работы предусмотрено 4 часа.
Лабораторная работа 6. Другие формы рекурсии
Цель занятия: изучить различные формы рекурсии, научиться использовать параллельную, взаимную рекурсию и рекурсию высших порядков для реализации функций обработки списков.
Порядок выполнения работы:
1. Изучить учебные материалы, представленные в презентации лабораторного практикума. При изучении материала необходимо повторить все представленные в презентациях примеры.
2. Выполнить задания в конце презентации лабораторного практикума.
В результате выполнения данной работы студенты должны научиться использовать различные формы рекурсии для построения функций для работы со списками и множествами, представленными списками.
На выполнение лабораторной работы предусмотрено 4 часа.
Лабораторная работа 7. Функционалы
Цель работы: изучить виды функционалов и способы их использования.
Порядок выполнения работы:
1. Изучить учебные материалы, представленные в презентации лабораторного практикума. При изучении материала необходимо повторить все представленные в презентациях примеры.
2. Выполнить задания в конце презентации лабораторного практикума.
В результате выполнения данной работы студенты должны научиться применять функционалы для вычислений.
На выполнение лабораторной работы предусмотрено 2 часа.
Защита лабораторных и семестровых работ
Для защиты лабораторной или семестровой работы необходимо представить отчет, содержащий следующие сведения:
1. Введение.
2. Описание решаемой задачи.
3. Код задачи на Лиспе с комментариями.
4. Описание тестов, подтверждающих правильность работы программы.
При защите работы студент должен уметь объяснить алгоритм решения задачи, а также основные конструкции в тексте программы, обосновать полученные результаты.