Методические рекомендации для студентов по изучению курса «Функциональное программирование»

Вид материалаМетодические рекомендации

Содержание


Методические рекомендации по выполнению лабораторных работ
Подобный материал:
Методические рекомендации для студентов по изучению курса «Функциональное программирование»


Методические рекомендации по изучению теоретического материала


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

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

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

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

Для изучения теоретической части курса необходимо изучить вопросы, рассматриваемые в лекциях. При изучении материала необходимо помимо лекционных материалов использовать рекомендуемую литературу для лучшего усвоения материала.


^ Методические рекомендации по выполнению лабораторных работ


Лабораторная работа 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. Описание тестов, подтверждающих правильность работы программы.


При защите работы студент должен уметь объяснить алгоритм решения задачи, а также основные конструкции в тексте программы, обосновать полученные результаты.