- •Лабораторне заняття № 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. Експертна система аналізу поточної успішності студентів на факультеті.
- •С.В. Зікратий, х.В. Паньків системи штучного інтелекту лабораторний практикум
8.5 Зміст звіту з лабораторної роботи
1. Вказати номер, тему й мету лабораторної роботи. Вибрати завдання згідно з варіантом з таблиці 8.1.
Таблиця 8.1
№ |
Завдання |
1 |
Управління процесом нагріву води |
2 |
Управління процесом сповільнення автомобілю на трасі |
3 |
Управління процесом заповнення протічного басейну |
4 |
Управління процесом підвищенням тиску в барокамері |
5 |
Управління процесом підйому повітряної кулі |
6 |
Управління процесом занурення підводної лодки |
7 |
Управління процесом приземлення повітряної кулі |
8 |
Управління процесом кондиціонування повітря в приміщенні |
2. Навести fis – структуру експертної системи.
3. Відобразити початкові та оптимізовані функції належності та базу правил.
4. Зробити порівняльні висновки стосовно роботи системи з різним настройками.
8.6 Контрольні питання
1. Для чого призначений пакет Fuzzy Logic Toolbox? Назвати основні властивості.
2. Для чого призначений графічний редактор нечіткої системи виведення?
3. Як викликати FIS–редактор?
4. Для чого призначений графічний інтерфейс гібридних мереж?
5. Що дозволяє виконувати програма кластеризації?
6. Дати визначення експертної системи.
7. Що таке функції належності? Як викликати редактор для їх задання?
8. Які види функцій належності ви знаєте?
9. Де можна задати правила для системи?
10. Що таке поверхня відгуку нечіткої системи? Як її переглянути?
11. Які галузі застосування подібних експертних систем?
12. Пояснити принцип дії даної експертної системи.
Лабораторна робота № 9 порівняльне дослідження роботи алгоритмів мамдані та сугено
Мета роботи: Освоїти принципи роботи алгоритмів Мамдані та Сугено. Навчитися задавати властивості системи залежно від поставленої задачі та алгоритму рішення.
9.1 Вступ
Алгоритми нечіткого виведення різняться, головним чином, видом використовуваних правил, логічних операцій і різновидом методу дефазифікації. Розроблені моделі нечіткого виведення Мамдані, Сугено, Ларсена, Цукамото. При розгляді алгоритмів для спрощення припустимо, що базу знань організують два нечітких правила вигляду:
П1: якщо х є А1 та у є В1, то z є С1,
П2: якщо х є А2 та у є В2, то z є С2,
де х і у – імена вхідних змінних, z – ім’я змінної виведення, А1, А2, В1, В2, С1, С2 – деякі задані функції належності, при цьому чітке значення z0 необхідно визначити на основі наведеної інформації та чітких значень x0 і y0.
9.2 Алгоритм Мамдані (Mamdani)
Алгоритм Мамдані є одним з перших, який знайшов застосування в системах нечіткого виведення. Він був запропонований 1975 р. англійським математиком Е. Мамдані (Ebrahim Mamdani) як метод для керування паровим двигуном. Формально алгоритм Мамдані може бути визначений таким чином.
Процедура фазифікації: визначаються ступені істинності, тобто значення функцій належності для лівих частин кожного правила (передумов): А1(x0), А2(x0), В1(y0), В2(y0).
Нечітке виведення: знаходяться рівні відтинання для передумов кожного з правил з використанням операції мінімум:
1 = А1(х0) В1(у0),
2 = А2(х0) В2(у0),
де через «» позначена операція логічного мінімуму (min), потім знаходяться «зрізані» функції належності
С1(z) = (1 C1(z)),
С2(z) = (2 C2(z)).
Композиція: з використанням операції максимуму (max, позначення: «») виконується об'єднання знайдених зрізаних функцій, що приводить до отримання підсумкової нечіткої підмножини для змінної виходу з функцією належності
(z) = C(z) = C1(z) C2(z) = (1 C1(z)) (2 C2(z)).
Приведення до чіткості (для знаходження z0) проводиться, наприклад, центроїдним методом (як х – координата центра ваги функції належності підсумкової нечіткої підмножини для змінної виходу):
Алгоритм ілюструється рис. 9.1:
Рисунок 9.1 – Графічна реалізація
