- •Функциональное и логическое программирование
- •Глава 1. Классификация языков и стилей программирования 3
- •Глава 2. Программирование на языКе лисп 16
- •Глава 3. Программирование на языке пролог 89
- •Глава 1. Классификация языков и стилей программирования
- •Основные парадигмы программирования
- •Процедурное (императивное, директивное) программирование.
- •Объектно-ориентированное программирование.
- •Декларативное программирование
- •Логическое программирование.
- •Функциональное программирование.
- •Классификация языков программирования
- •Функциональные языки
- •Логические языки
- •Глава 2. Программирование на языКе лисп
- •История создания языка Лисп
- •Диалекты языка Лисп
- •Лисп-машины
- •Область применения языка Лисп
- •Особенности языка Лисп Одинаковая форма данных и программ
- •Хранение данных, не зависящее от места
- •Автоматическое и динамическое управление памятью
- •Функциональная направленность
- •Динамическая проверка типов
- •Интерпретирующий и компилирующий режимы работы;
- •Пошаговое программирование
- •Единый системный и прикладной язык программирования
- •Основы языка Лисп
- •Понятие функции.
- •Quote блокирует вычисления
- •Базовые функции языка.
- •Функция car возвращает в качестве значения первый элемент списка.
- •Функция cdr - возвращает в качестве значения хвостовую часть списка, т. Е. Список, получаемый из исходного списка после удаления из него головного элемента:
- •Функция cons включает новый элемент в начало списка:
- •Предикат equal проверяет идентичность записей:
- •Предикат equalp проверяет наиболее общее логическое равенство:
- •Другие простейшие встроенные функции Лиспа. Функция null проверяет, является ли аргумент пустым списком:
- •Комбинации вызовов car и cdr позволяют получить любой элемент списка:
- •Наиболее общая функция, выделяющая n-й элемент списка (при этом индексация начинается с 0):
- •Функция last позволяет выделить последний элемент списка:
- •Функция list - создает список из элементов:
- •Функция setq – невычисляющее присваивание:
- •Функция setf - обобщенная функция присваивания:
- •Функции, обладающие побочным эффектом, называются псевдофункциями.
- •С символом можно связать именованные свойства:
- •Функция get - возвращает значение свойства, связанного с символом:
- •Псевдофункция remprop удаляет свойство и его значение:
- •Вызов интерпретатора eval вычисляет значение выражения.
- •Ввод и вывод.
- •Использование файлов.
- •Определение функций
- •Задание параметров в лямбда-списке.
- •Передача параметров и область их действия.
- •Вычисления в лисПе.
- •Предложение let создает локальную связь внутри формы:
- •Последовательные вычисления.
- •Разветвление вычислений.
- •Циклические вычисления.
- •Передача управления.
- •Другие циклические структуры.
- •Динамическое управление из другого контекста
- •Внутреннее представление списков
- •Функциональное программирование Рекурсия. Различные виды рекурсии.
- •Функции более высокого порядка.
- •Применяющие функционалы.
- •Отображающие функционалы.
- •Макросы
- •Типы данных
- •Основные типы данных:
- •Глава 3. Программирование на языке пролог
- •Общие сведения о языке Пролог. Язык Пролог как система, реализующая логический вывод в исчислении предикатов первого порядка.
- •Фразы Хорна как средство представления знаний.
- •Синтаксис языка Пролог.
- •Фразы, термы, факты, правила.
- •Константы:
- •Простейшая программа на Прологе
- •Выполнение запроса в Прологе.
- •Неудача запроса и возврат назад.
- •Декларативная и процедурная семантика Пролога.
- •Рекурсивные процедуры.
- •Списки.
- •Операторы.
- •Средства управления ходом выполнения программы. Предикат сократить (отсечение).
- •Отрицание как неудача запроса.
- •Встроенные предикаты.
- •Типы отношений.
- •Ограничения, обеспечивающие целостность отношений.
- •Свойства отношений.
- •Подходы к программированию на языке Пролог.
Понятие функции.
Функцией в математике называют отображение, которое однозначно отображает одни значения на другие. Например, запись
f(x) → y
ставит в соответствие каждому элементу х из множества определения единственный элемент y из множества значений функции f. Будем говорить, что функция f от аргумента х имеет значение y= f(x). У функции может произвольное число аргументов, в том числе не может совсем.
Определение функции в Лиспе позволяет задать произвольное вычислимое отображение. В процедурных языках программирования для вызова функции используется префиксная нотация, т.е. имя функции стоит перед скобками, окружающими аргументы:
f (x), fun (x, y), h (x, g (y, z)).
В арифметических выражениях используется инфиксная запись, в которой имя функции, т.е. действия, располагается между аргументами:
x+у, x-y, x*(y+z).
Для записи функций и выражений в Лиспе используется списочная форма записи, при которой имя функции или действия, а также аргументы записываются внутри скобок:
(+ x y), (- x y), (* x (+ y z) ).
В конструкцию функции могут, в свою очередь, входить функциональные подвыражения. Тогда аргументы вычисляемой функции заменяются на новые вычисления, ведущие к определению значений этих аргументов.
Quote блокирует вычисления
В некоторых случаях не надо вычислять значение выражения, а нужно само выражение. В таких случаях выражения, которые не нужно вычислять, помечаются апострофом «’»:
'(+ 2 3 ) => (+ 2 3)
Апостроф перед выражением это сокращение Лисповской формы QUOTE:
' s-выражение ↔ (QUOTE s-выражение)
Базовые функции языка.
В Лиспе для построения, разбора и анализа списков существуют базовые функции. Базовые функции в определенном смысле образуют систему аксиом языка, к которым сводятся символьные вычисления. Простота базовых функций и их малое число – это характерные черты Лиспа. С этим связана математическая элегантность языка.
Базисными функциями обработки символьных выражений являются:
CAR, CDR, CONS, ATOM, EQ.
Функции по принципу их использования можно разделить на функции разбора, создания и проверки:
Использование |
Вызов |
Результат |
Разбор |
(CAR, список) (CDR, список) |
s-выражение список |
Создание |
(CONS s-выражение, список) |
список |
Проверка |
(ATOM, s-выражение) (EQ, символ, символ) |
T или NIL T или NIL |
Функция car возвращает в качестве значения первый элемент списка.
(CAR список) => s - выражение (атом либо список).
Функция CAR имеет смысл только для аргументов, являющихся списками:
(CAR ‘a) => Error
(CAR ‘(a b c d)) => a
(CAR ‘((a b) c d)) => (a b)
(CAR ‘(a)) => a
(CAR NIL) => NIL - (голова пустого списка - пустой список).
Вызов функции CAR с аргументом (a b c d) без апострофа был бы проинтерпретирован как вызов функции «a» с аргументом «b c d», и было бы получено сообщение об ошибке.
Функция cdr - возвращает в качестве значения хвостовую часть списка, т. Е. Список, получаемый из исходного списка после удаления из него головного элемента:
(CDR список) => список
Функция CDR (произносится «кудр») определена только для списков. Функция берет остаток списка без первого элемента, т.е. хвост. Если список состоял из одного элемента, то результатом выполнения функции будет пустой список, т.е. NIL:
(CDR ‘a) => Error
(CDR ‘(a b c d)) => (b c d)
(CDR ‘((a b) c d)) => (c d)
(CDR ‘(a (b c d))) => ((b c d))
(CDR ‘(a)) => NIL
(CDR NIL) => NIL
