- •Лабораторне заняття № 1 Ознайомлення з мовою програмування Пролог
- •1.1 Загальні відомості про мову Пролог
- •1.2 Елементи мови Пролог
- •1.3 Структура програм Пролога
- •1.3.1 Секція domains Пролог-програми
- •1.3.2 Секція predicates
- •1.3.3 Секція clauses
- •1.3.4 Секція goal
- •1.3.5 Секція database
- •1.4 Розробка найпростішого інтерфейсу програми
- •1.5 Використання структур як доменів відношень
- •1.6 Процедури як елемент представлення знань
- •1.7 Цілісність і несуперечність баз даних і знань
- •1.8 Зміст звіту з лабораторної роботи
- •Лабораторна робота № 2 Керування ходом виконання програм у системі Пролог
- •2.1 Робота системи Пролог при виконанні запитів
- •2.2 Уніфікація термів
- •2.3 Пошук з поверненням при виконанні Пролог-програм
- •2.4 Використання відкату після невдачі для організації найпростішого інтерфейсу виводу
- •2.5 Організація повторюваних процесів
- •2.6 Керування пошуком з поверненням
- •2.7 Керування ходом виконання програм з використанням відсікання
- •2.8 Застосування предикату not -- заперечення як неуспіх
- •2.9 Використання методу відкату і відсікання
- •2.10 Відкат і відсікання при реалізації відносин типу „один-до-багатьох”
- •2.11 Ступінчаті функції і відсікання
- •2.12 Труднощі у використанні відсікання і заперечення
- •2.13 Зміст звіту з лабораторної роботи
- •Лабораторна робота № 3 Рекурсія і рекурсивні процедури в Пролозі
- •3.1 Визначення поняття рекурсії
- •3.2 Склад рекурсивної процедури
- •3.3 Особливості виконання рекурсивних процедур Прологом-системою
- •3.4 Приклад рекурсивної процедури пошуку довжини маршруту на графі
- •3.5 Обмеження і властивості, що забезпечують цілісність відношень
- •3.6 Зміст звіту з лабораторної роботи
- •Лабораторна робота № 4 Списки і процедури їх обробки
- •4.1 Списки як рекурсивні структури даних
- •4.2 Використання списків у Пролог-програмах
- •4.3. Найпростіші процедури роботи зі списками
- •4.4 Процедури обробки списків
- •4.5. Компонування даних у список
- •4.6. Зміст звіту з лабораторної роботи
- •Лабораторна робота № 5 Способи представлення баз даних у Пролог-програмах
- •5.1 Вступ
- •5.2 Представлення відносин у вигляді фактів
- •5.3 Представлення атрибутів у вигляді фактів
- •5.4 Представлення бази даних у вигляді списку структур
- •5.5 Представлення бази даних у вигляді лінійної рекурсивної структури
- •5.6 Представлення бази даних у вигляді двійкового дерева
- •5.7 Порівняння різних видів представлення бази даних
- •Лабораторна робота № 6 Динамічні бази даних
- •6.1 Вступ
- •6.2 Прості прийоми роботи з динамічними бд
- •6.3 Зв’язок статичних і динамічних баз даних
- •6.4 Процедура роботи з динамічною бд, що навчається у користувача
- •6.5 Розширення бази даних у файли
- •6.6. Організації файлових бд на основі файлів прямого доступу
- •6.6. Особливості представлення динамічних баз даних у Visual Prolog
- •6.7 Зміст звіту з лабораторної роботи
- •Лабораторна робота № 7 створення простої експертної системи
- •7.1 Вступ
- •7.2 Завантаження бази знань і режим консультації
- •7.2 Структура бази знань esta
- •7.3 Формати файлів баз знань в esta
- •7.4 Елементарні прийоми роботи з секціями
- •7.5 Елементарні прийоми роботи з параметрами
- •7.6. Зміст звіту з лабораторної роботи
- •Лабораторна робота № 8 розробка нечітких систем керування з використанням fuzzy logic toolbox математичного пакета matlab
- •8.1 Вступ
- •8.2 Склад графічного інтерфейсу
- •8.3 Редактор бази знань RuleEditor
- •8.4 Вступ Приклад виконання роботи
- •8.5 Зміст звіту з лабораторної роботи
- •8.6 Контрольні питання
- •Лабораторна робота № 9 порівняльне дослідження роботи алгоритмів мамдані та сугено
- •9.1 Вступ
- •9.2 Алгоритм Мамдані (Mamdani)
- •9.3 Алгоритм Сугено (Sugeno)
- •9.4 Порядок виконання роботи
- •9.5 Зміст звіту з лабораторної роботи
- •9.6 Контрольні питання
- •Список використаних джерел
- •Додаток а Службові предикати Пролога для роботи з файлами
- •Додаток б Індивідуальні завдання До лабораторних робіт № 1, 2, 4
- •Додаток в Індивідуальні завдання До лабораторної роботи № 3
- •Додаток г Індивідуальні завдання до лабораторної роботи № 5
- •Додаток д варіанти завдань до виконання лабораторної роботи № 7
- •Тема 11. Експертна система аналізу поточної успішності студентів на факультеті.
- •С.В. Зікратий, х.В. Паньків системи штучного інтелекту лабораторний практикум
5.5 Представлення бази даних у вигляді лінійної рекурсивної структури
Ще одним зі способів представлення в пам'яті ЕОМ записів баз даних є використання рекурсивних структур, у яких один з аргументів кожного запису вказує на наступний запис. Рекурсивні структури – аналог однозв’язних списків в інших мовах програмування, але працювати з такими структурами в Пролозі легше, тому що він бере на себе всі дії з обробки покажчиків.
Для того, щоб на Пролозі створити рекурсивну структуру, що складається з записів work() („службовці”), єдине, що потрібно – це ввести в цю структуру додатковий аргумент, що вказує на наступний запис, у структурі якої також буде міститися аргумент, що вказує на наступний за ним запис і т.д. Для вказівки в останньому записі відсутності наступного за ним запису, як додатковий аргумент уводиться „end”. Розглянемо приклад лінійної рекурсивної структури Службовець(Ім’я, Відділ, Посада, Оклад , Покажчик на наступний запис).
Використовуючи синтаксис мови Пролог, позначимо цю структуру work3(). За аналогією з раніше розглянутим прикладом, вона буде містити три записи
work3(„Маслов”, 101, „оператор”, 200,
work3(„Денега”, 211, „начальник”, 450,
work3(„Петренко”, 101, „менеджер”, 300, end)))
Як видно, рівень вкладеності в кожному новому записі буде більший, ніж у попередньому. У п’ятому полі останнього запису міститься слово „end”, що означає, що більше записів немає. Слід зазначити, що додатковий аргумент структури, що вказує на наступні записи бази даних, сам має структуру цього запису. Тобто структура запису визначається сама через себе: Службовець(Ім’я, Відділ, Посада, Оклад, Службовець).
База даних, сформована у вигляді рекурсивної структури, повинна дозволяти виконувати запити і модифікувати дані. Одним з основних вимог є можливість доступу до цілісного інформаційного елемента (запису) БД. Розглянемо варіант процедури record(), що модифікована таким чином, щоб стала можливою обробка рекурсивної структури.
Першим (вихідним) аргументом нової процедури є структура work(), що містить чотири аргументи і відповідає запису бази даних. Другий аргумент цієї процедури – це сама БД у вигляді рекурсивної структури. Процедура складається з двох правил. Перше з них будує структуру work() з верхнього рівня рекурсивної структури даних. Друге правило ігнорує верхній рівень рекурсивної структури та одержує наступний цілісний інформаційний елемент із частини бази, що залишилася, даних (позначена змінною NextRecord).
record(work(Name, Office, Post, Salary), work3(Name, Office, Post, Salary, NextRecord)).
record(work(Name, Office, Post, Salary), work3(_,_,_,_, NextRecord)) :- work3(work(Name, Office, Post, Salary), NextRecord).
Використовуючи процедуру record(), можна сформувати зовнішню мету для запиту по знаходженню всіх службовців 101 відділу, за умови, що другим аргументом процедури буде вся база даних.
Goal: record (work(Name, 101, Post, Salary), work3(„Маслов”, 101, „оператор”, 200, work3(„Денега”, 211, „начальник”, 450, work3(„Петренко” ,l01, „менеджер”, 300, end))).
Відповідь на цей запит буде отримана у вигляді:
Name=Маслов,
Post=onepaтop,
Salary=200
Name=Петренко,
Post=менеджер,
Salary=300
Аналогічний варіант запиту реалізований як мета print_101 програми 5.1.
/* Програма 5_1 */
domains
name = symbol
office = integer
worker = work(name,office)
/* опис рекурсивної структури */
work3 = work3(name, office, work3); end
predicates
print_101
record(worker, work3)
goal
print_101.
clauses
record(work(X, Y), work3(X, Y, _)).
record(work(X, Y), work3(_, _, Z)):- record(work(X, Y), Z).
print_101:- write(„Співробітники 101 відділу”), nl, record(work(X, 101), work3(„Маслов”, 101, work3(„Денега”, 211, work3(„Петренко”, 101, end)))), write(X), nl, fail.
Ця програма працює з БД work3(), представленою у вигляді лінійної рекурсивної структури. Для спрощення програми в БД work() використовується лише два поля (Прізвище і Відділ), тобто інформаційні елементи work(), містять лише по два компоненти.
Процедура record() дозволяє виконувати доступ до окремого запису БД.
