- •Лабораторне заняття № 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. Експертна система аналізу поточної успішності студентів на факультеті.
- •С.В. Зікратий, х.В. Паньків системи штучного інтелекту лабораторний практикум
3.6 Зміст звіту з лабораторної роботи
Вказати номер, тему й мету лабораторної роботи.
Написати програму для знаходження швидкості сходження ряду (див. додаток В), тобто кількості кроків, за які досягається задана точність (0,01). Для реалізації цієї мети слід написати предикати для обчислення факторіалу (варіанти 1–7) або степеня (варіанти 8–16) та знаходження n-го члену ряду.
Навести результат виконання програми.
Лабораторна робота № 4 Списки і процедури їх обробки
Мета роботи: Ознайомитися з використанням списків у Пролог-програмах та з перетворенням набору фактів у списки. Вивчити рекурсивних процедур обробки списків.
4.1 Списки як рекурсивні структури даних
Список – широко використовувана структура даних, яку зручно застосовувати при рекурсивній обробці інформації, склад і кількість якої змінюється в ході процесу обробки.
Список – упорядкована послідовність елементів, що може мати довільну довжину. Елементами списку можуть бути будь-які терми:
– константи;
– змінні;
– структури, що можуть включати й інші списки.
Списки широко використовуються при створенні баз даних і знань, експертних систем, карт міст, програм на ЕОМ і математичних об'єктів (графи, формули, функції).
Список – це або порожній список (записується в квадратних дужках []), що не містить жодного елемента, або структура, що має у своєму складі два компоненти: “голову” і “хвіст” списку.
“Голова” і “хвіст” списку є компонентами функтора, що позначається крапкою. Наприклад, список, що складається з одного символьного елемента “а” може бути записаний у вигляді. (а,[]) і його представлення у вигляді дерева має структуру, наведену на рис 4.1, а.
Рисунок
4.1 – Представлення списку
Розглянемо ще один приклад. Нехай є список, що складається з трьох символьних даних ’а’, ’b’, і ’с’, який можна записати у вигляді: (а, (b, (с, []))) або представити у вигляді бінарного дерева, структура якого приведена на рис.4.1,б.
Запис складних списків за допомогою функтора не зручний, тому в Пролозі використовується інша форма запису, при якій елементи списку заключаються у квадратні дужки і розділяються комами. Так для розглянутих прикладів запис списків з використанням скобкової форми запису буде мати вигляд: [а] та [а, b, c], відповідно.
Непорожній список можна розглядати як список, що складається з двох частин:
– першого елемента списку – голови списку;
– частини списку, що залишилася – хвоста списку.
Голова є елементом списку і є неподільною. Хвіст – це є список, що складається з всіх елементів вихідного списку, за винятком першого елемента. Хвіст може бути поділений і далі на голову і хвіст.
Виконуючи аналогічні операції, цей процес можна продовжувати, поки список не стане порожнім. З цього випливає очевидний висновок, що список є рекурсивною структурою даних.
У Пролозі введена спеціальна форма для представлення списку з “головою” Х и “хвостом” Y, де для поділу на Х та Y використовується символ вертикальної риски, тобто [Х | Y].
Використовуючи даний підхід, список [а, b, c] можна записати як [a | [b, c]]. Тут “а” – голова списку, перший його елемент, а [b, c] – “хвіст” списку, частина списку, що починається з другого елемента.
