- •Міністерство освіти і науки, молоді та спорту україни Тернопільський національний технічний університет імені Ів. Пулюя
- •Лабораторне заняття №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 Налагодження і трасування програм
- •Лабораторна робота №2 Робота з найпростішими програмами в системі Турбо-Пролог
- •2.1 Вступ
- •2.2 Завантаження системи Турбо-Пролог, ввід і запуск програм
- •2.3 Робота з Пролог-програмами в режимі діалогу
- •2.4 Трасування програм у середовищі системи Турбо-Пролог
- •2.5 Робота з програмами, що містять внутрішню мету
- •2.6. Найпростіша програма вводу-виводу даних
- •2.7 Побудова найпростішого інтерфейсу для виводу результатів запитів
- •8. Зміст звіту по лабораторній роботі
- •Лабораторна робота №3 Пролог-програми як найпростіші бази даних і знань
- •3.1 Вступ
- •3.2 Запити до бази даних
- •3.2.1 Прості запити
- •3.2.2 Складені запити
- •3.2.3 Запити з анонімними змінними
- •3.3. Статичні і динамічні бази даних
- •3.4. Явні і неявні бази даних. Правила логічного висновку
- •3.5 Використання структур у якості доменів відношень
- •6. Процедури як елемент представлення знань
- •3.7 Цілісність і несуперечність баз даних і знань
- •3.8. Зміст звіту по лабораторній роботі
- •Лабораторна робота №4. Керування ходом виконання програм у системі Турбо-Пролог
- •4.1 Робота системи Турбо-Пролог при виконанні запитів
- •4.2 Уніфікація термів
- •4.3 Пошук з поверненням при виконанні Пролог-програм
- •4.4 Використання відкату після невдачі при використанні внутрішньої мети для організації найпростішого інтерфейсу виводу
- •4.5 Зміст звіту по лабораторній роботі
- •Лабораторна робота №5 Керування ходом виконання Пролог-програм
- •5.1 Організація повторюваних процесів
- •5.2 Керування пошуком з поверненням
- •5.3 Керування ходом виконання програм з використанням відсікання
- •5.4 Застосування предикату not - заперечення як неуспіх
- •5.5 Використання методу відкату і відсікання
- •5.6 Відкат і відсікання при реалізації відносин типу „один-до-багатьох”
- •5.7 Ступінчаті функції і відсікання
- •5.8 Труднощі у використанні відсікання і заперечення
- •5.9 Зміст звіту по лабораторній роботі
- •Лабораторна робота №6 Рекурсія і рекурсивні процедури в Пролозі
- •6.1 Визначення поняття рекурсії
- •6.2 Склад рекурсивної процедури
- •6.3 Особливості виконання рекурсивних процедур Прологом-системою
- •6.4 Приклад рекурсивної процедури пошуку довжини маршруту на графі
- •6.5 Обмеження і властивості, що забезпечують цілісність відношень
- •6.6 Реалізація циклічних процедур за допомогою бектрекінгу
- •6.6.1. Реалізація ітераційного процесу за допомогою бектрекінгу
- •6.6.2 Дії типу ’до’ і ’після’
- •6.6.3. Застосування бектрекінгу для реалізації циклів
- •6.7 Зміст звіту по лабораторній роботі
- •Лабораторна робота №7 Списки і процедури їх обробки
- •7.1 Списки як рекурсивні структури даних
- •7.2 Використання списків в Пролог-програмах
- •7.3. Найпростіші процедури роботи зі списками
- •7.4 Процедури обробки списків
- •7.5. Компонування даних у список
- •7.6. Зміст звіту по лабораторній роботі
- •Лабораторна робота №8 Способи представлення баз даних у Пролог-програмах
- •8.1 Вступ
- •8.2 Представлення відносин у виді фактів
- •8.3 Представлення атрибутів у виді фактів
- •8.4 Представлення бази даних у виді списку структур
- •8.5 Представлення бази даних у виді лінійної рекурсивної структури
- •8.6 Представлення бази даних у виді двійкового дерева
- •8.7 Порівняння різних видів представлення бази даних
- •Лабораторна робота №9 Динамічні бази даних
- •9.1 Вступ
- •9.2 Прості прийоми роботи з динамічними бд
- •9.3 Зв’язок статичних і динамічних баз даних
- •9.4 Процедура роботи з динамічною бд, що навчається у користувача
- •9.5 Розширення бази даних у файли
- •9.6. Організації файлових бд на основі файлів прямого доступу
- •9.6. Особливості представлення динамічних баз даних у Visual Prolog
- •9.7 Зміст звіту по лабораторній роботі
- •Лабораторна робота №10 робота з складно структурованими базами даних
- •10.1 Опис логічної моделі даних
- •10.3 Отримання структурованої інформації з бази даних
- •10.4 Абстракція даних і побудова баз знань
- •10.5. Зміст звіту по лабораторній роботі
- •Лабораторна робота №11 дослідження методів представлення і обробки знань
- •11.1 Структура експертних систем
- •11.2 Представлення знань
- •11.3 Система інтерфейсу користувача
- •11.4 Експертна система на правилах
- •11.5 Експертні системи, що базуються на логіці
- •11.6 Структура бази знань експертної системи для вибору породи дерева
- •11.7 Зміст звіту
- •Список використаних джерел
- •Додаток а Службові предикати Турбо-Пролога
- •Додаток б Службові предикати Турбо-Пролога для роботи з файлами
- •Додаток в
- •Таблиця в.1 – Варіанти завдань
- •6. До лабораторної роботи №7
- •7. До лабораторної роботи №8
- •8. До лабораторної роботи №9
- •9. До лабораторної роботи №10
- •10. До лабораторної роботи №11
Лабораторна робота №3 Пролог-програми як найпростіші бази даних і знань
Ціль роботи:
1. Знайомство з організацією баз даних як сукупності фактів.
2. Одержання навичок організації явних і неявних баз даних.
3. Вивчення способів побудови універсальних запитів до баз даних.
4. Знайомство з представленням знань у вигляді правил і процедур.
3.1 Вступ
Система понять для представлення знань трохи відрізняється від понять для представлення даних. Разом з тим база знань (БЗ) здатна зберігати дані і як простий різновид знань у вигляді бази даних (БД). Відповіді на запити, що формує користувач до бази, реалізуються одним із двох можливих способів:
– повідомленням, що є відповіддю на запит, зберігаються в явному виді в БД, і процес одержання відповіді являє собою виділення із БД підмножини значень, що задовольняють запитові;
– відповідь не існує в явному виді в БД і формується в процесі логічного висновку на підставі наявних даних.
Останній випадок принципово відрізняється від технологій використання БД і розглядається в рамках представлення знань, тобто інформації, необхідної в процесі отримання нових фактів. У Пролог-програмах виведення нових фактів можливе на підставі набору правил, що включаються в програму і являють собою спрощений варіант БЗ. Представлення знань у виді набору правил має наступні переваги:
– простота створення і розуміння окремих правил;
– простота механізму логічного висновку.
До недоліків цього способу організації БЗ відноситься її відмінність від людської структури знань.
3.2 Запити до бази даних
Найпростіша Пролог-програма є множиною фактів, що неформально називають базою даних.
Розглянемо приклад. Нехай для збереження інформації про службовців і місця їхньої роботи необхідно створити БД з наступною структурою відношення Працює(Ім’я, Відділ). При цьому атрибут Ім’я описує домен даних типу рядок символів, а атрибут Відділ – домен цілочисельних даних.
Для рішення поставленої задачі в Пролог-програмі:
– вихідне відношення описується предикатом аналогічної структури;
– у секції domains задаються області зміни кожного аргументу предикату;
– кожен кортеж даного відношення представляється в секції clauses у вигляді факту.
Одним із прикладів програми, що реалізують дану задачу, може бути програма 3.1.
/* Програма 3.1 */
domains
namе=string
office=integer
predicates
work(name, office)
clauses
work(„Грищенко”, 101).
work(„Кардаш”,111).
work(„Петренко”, 101).
3.2.1 Прості запити
Простий запит складається з імені предиката, за яким розташовується список аргументів.
Якщо в запит входять тільки константи (тобто атоми і числа), то такий запит називається запитом з константами і на нього система видає тільки одину із двох відповідей – True(Yes) або False(No). Відповідь True свідчить про те, що система довела істинність запиту відповідно до множини фактів, завантажених у неї в даний момент. Відповідь False – про неможливість системи довести істинність запиту. В цьому випадку, наприклад, наступні запити можна трактувати наступним чином
Goal: work(„Грищенко”, 101).
Yes
“чи працює Грищенко у 101 відділі?”, а відповідь на нього можна трактувати наступним чином: “Так, працює Грищенко у 101 відділі”.
Goal: work(„Грищенко”, 111)
False
“чи працює Грищенко у 111 відділі?", відповідь “Ні, не працює Грищенко у 111 відділі”
Однак застосування запитів з константами досить обмежено, тому найбільше часто застосовуються запити, що використовують змінні – запити з змінними.
Змінна – це вид терму, що починається з заголовної латинської букви. У запиті, що містить змінну, неявно запитується про те, чи існує хоча б одне значення змінної, при якому запит буде щирим. Тобто змінні в запитах квантифіковані екзістенціально. Якщо мати це на увазі, то наступний діалог з програмою
Goal: work(Who, 101).
Who=„Грищенко”,
Who=„Петренко”,
можна прочитати так “чи існує хоча б одна людина, що працює в 101-му відділі?”. Запит буде щирим, якщо хоча б одну особу буде знайдено в поточній базі.
Система намагається уніфікувати (тобто погодити) аргументи запиту з аргументами фактів, що входять у базу даних “work”. Запит виявиться успішним при його зіставленні з першим же фактом, оскільки атом “101” у запиті уніфікується з атомом „101” першого факту, а змінна “Who” уніфікується з атомом “Грищенко”, що входить у цей факт. У результаті даного процесу змінна “Who” прийме значення атому “Грищенко”, повідомлення про що і виводиться у вікні діалогу.
Далі відбувається зіставлення запиту з іншими фактами БД і інформація про всі успішні уніфікації та їх кількість виводиться у вікні діалогу. Говорять, що змінна конкретизується, коли при виконанні запиту вона уніфікується з деяким значенням.