- •Общие сведения о Прологе, области применения, отличия Пролога от других языков программирования.
- •4. Способы объявления доменов (типов данных) в Турбо-Прологе.
- •5.Объявление предикатов в программах Турбо-Пролога.
- •6. Утверждения программы Турбо-Пролога: факты и правила.
- •7.Внутренняя и внешняя цели в программах Турбо-Пролога.Раздел goal
- •8.Этапы программирвоания на тп
- •9.Декларативный и процедурный смысл программы на Турбо-Прологе.
- •10.Сопоставление. Правила сопоставимости термов, структур.
- •11.Арифметика в тп, Арифметические функции в тп
- •12.Рекурсия.Пример рекурсивного правила(вычисление факториала, возведение числа в целую степень).
- •13 Стандартные предикаты. Поточный шаблон стандартного предиката.
- •14 Стандартные предикаты ввода-вывода в Турбо-Прологе.
- •15Отсечение в программах на Турбо-Прологе.
- •16Списки. Описание списков в программе. Голова и хвост списка.
- •17Основные стандартные предикаты Турбо-Пролога для работы со строками.
- •18Преобразование строки в список символов.
- •Преобразование строки в символ
- •19 Преобразование строки в список атомов
- •20 Основные предикаты Турбо Пролога для преобразования данных из одного типа в другой
- •Преобразование строки в символ
- •Преобразование, определяемые пользователем
- •21Предикаты Турбо-Пролога для переадресации внешних устройств.
- •22 Описание файловых доменов в Турбо-Прологе.
- •23 Запись данных в файл в программах на Турбо-Прологе.
- •24 Чтение данных из файла в программах на Турбо-Прологе.
- •25 Дозапись данных в конец существующего файла в программах на Турбо-Прологе
- •26 Предикаты Турбо-Пролога для работы с окнами
- •27Статические и динамические базы данных в программах на Турбо-Прологе
- •28Создание динамических баз данных средствами Турбо-Пролога
- •30Способы занесения информации в динамическую базу данных
- •29Предикаты Турбо-Пролога для работы с базой данных.
- •Общие сведения о Прологе, области применения, отличия Пролога от других языков программирования.
- •Основные элементы Турбо-Пролога: имена объектов, термы, константы, переменные, структуры, атомы.
27Статические и динамические базы данных в программах на Турбо-Прологе
БД – это упорядоченная совокупность данных, записанных в доступном для компьютера формой.
Предикаты БД в ТПр описываются в разделе database, который должен располагаться перед разделом predicates. Все утверждения с предикатами, описанными в database, составляют динамическую БД. БД называется динамической, так как во время работы программы у нее (БД) можно удалять любые содержащиеся в ней утверждения, а так же добавлять новые, в этом отличие от статической, где утверждения являются частью кода программы и не могут быть изменены во время программы.
Другая особенность ДБД с том, что БД может быть записана на диск и считана с него в ОП. Например, в ДБД содержаться сведения об игроках футболистах dplayer. Тогда требуется следующее описание в программе
domains
name, team=symbol
number = integer
database
dplayer (name, team, number)
Иногда бывает лучше иметь часть информации БД в виде утверждений статической БД. Эти данные заносятся в ДБД сразу после активизации программы. Для этого используются предикаты asserta, assetz. Предикаты статической БД имеют другое имя, но ту же форму представления данных, что и предикаты ДБД. Предикат СБД, соответствующий предикату dplayer может быть представлен в программе следующим образом:
predicates
player (name, team, number)
clauses
player (“Adamov”, “Dinamo”, 5).
28Создание динамических баз данных средствами Турбо-Пролога
30Способы занесения информации в динамическую базу данных
БД – это упорядоченная совокупность данных, записанных в доступном для компьютера формой.
Предикаты БД в ТПр описываются в разделе database, который должен располагаться перед разделом predicates. Все утверждения с предикатами, описанными в database, составляют динамическую БД. БД называется динамической, так как во время работы программы у нее (БД) можно удалять любые содержащиеся в ней утверждения, а так же добавлять новые, в этом отличие от статической, где утверждения являются частью кода программы и не могут быть изменены во время программы.
Другая особенность ДБД с том, что БД может быть записана на диск и считана с него в ОП. Например, в ДБД содержаться сведения об игроках футболистах dplayer. Тогда требуется следующее описание в программе
domains
name, team=symbol
number = integer
database
dplayer (name, team, number)
Иногда бывает лучше иметь часть информации БД в виде утверждений статической БД. Эти данные заносятся в ДБД сразу после активизации программы. Для этого используются предикаты asserta, assetz. Предикаты статической БД имеют другое имя, но ту же форму представления данных, что и предикаты ДБД. Предикат СБД, соответствующий предикату dplayer может быть представлен в программе следующим образом:
predicates
player (name, team, number)
clauses
player (“Adamov”, “Dinamo”, 5).
В ДБД содержаться только факты, но не правила.
Правило для занесения в ДБД информации из утверждений предиката player служит:
assert_database:-
player (Name, Team, Number),
assertz (dplayer (Name, Team, Number)),
% Добавление указанного факта в ДБД
fail.
assert_database:-!.