Обмеження і властивості, що забезпечують цілісність відношень

 

Для простоти розглянемо тільки відношення між двома об'єктами (бінарні відносини). Для будь-якого бінарного відношення справедливо одне з обмежень: один-до-одного, один-до-багатьох, багато-до-багатьох. Крім цього, будь-яке відношення можна характеризувати наявністю або відсутністю таких властивостей як:

– симетрія (асиметрія);

– рефлексивність (нерефлективність);

– транзитивність (нетранзитивність);

За замовчуванням Пролог виконує дії з предикатами, вважаючи, що вони регулюються обмеженням виду багато-до-багатьох. При обліку обмежень виду один-до-багатьох можна скористатися додатковими відносинами і предикатом відсікання, як була мова в попередній роботі.

Бінарне відношення, реалізоване в мові Пролог, за замовчуванням має властивості рефлексивності, асиметричності і нетранзитивності.

Відношення між двома об'єктами буде симетричним, якщо ролі, що грають ці об'єкти, взаємозамінні.

Відношення, що виконуються, коли обидва об'єкти однакові, називається рефлексивним.

Відношення між об’єктами називається транзитивним, якщо воно зберігається при переході від прямого відношення до непрямого. Транзитивні відносини звичайно реалізуються рекурсивними процедурами типу “предок” або “маршрут”.

На логічних схемах симетричні відносини зображуються двонаправленою стрілкою, асиметричні – однонаправленою. Асиметричне транзитивне відношення з непрямими зв'язками через кілька рівнів буде виглядати як дерево, що росте вниз (рис. 3.1, с). Відношення, що є одночасно і симетричним, і транзитивним (типу „маршрут”), можна зобразити так, як показано на рис. 3.3.

Найпростіший спосіб змінити властивості відношень – це ввести в програму додаткові факти, що забезпечують дотримання цих властивостей. Так, якщо в програмі є факти

чоловік_жінка(„Іван”, „Марія”),

чоловік_жінка(„Петро”, „Галя”),

то відношення „чоловік_жінка” можна зробити симетричним шляхом додавання додаткових фактів зі зворотним положенням об'єктів:

чоловік_жінка(„Марія”, „Іван”),

чоловік_жінка(„Галя”, „Петро”),

Альтернативою застосування даного підходу є використання процедури, що встановлює симетричність, нерефлексивність або транзитивність. Так, процедура

чоловік_жінка_симетр(Чоловік1, Чоловік2):- чоловік_жінка(Чоловік1, Чоловік2),!.

чоловік_жінка_симетр(Чоловік1, Чоловік2):- чоловік_жінка(Чоловік2, Чоловік1).

встановлює симетрію відношення „чоловік_жінка”, а рекурсивна процедура „предок” установлює транзитивність відношення „предок”. Відношення „товариші_по_службі” перетворюється в нерефлексивне шляхом додавання останньої підмети

colleague(Man1, Man2) :- work(Man1, X), work(Man2, X), Man1<>Man2.

Таким чином, щоб поліпшити програму 3.2, можна базу даних “дороги” зробити симетричною шляхом введення додаткової процедури, а потім звернутися до цієї бази даних із процедури route(). Правило для route() при цьому автоматично успадкує симетрію бази даних “дороги”. Крім того, якщо ще додати підмету, що дозволить зробити відношення нерефлексивним, те це дозволить позбутися від деяких неточних відповідей системи.

Доробіть програму 3.2 так, щоб використовувані в ній відносини були б симетричними і нерефлексивними і випробуйте її. Спробуйте тепер визначити маршрут від Львова до Івано-Франківська. Спробуйте визначити ще ряд цілей. Спробуйте виключити предикат відсікання з другого правила. Спробуйте розширити базу “дороги” шляхом включення нових фактів, наприклад шляху до Києва через різні міста та дослідіть процес знаходження відстані між кінцевими точками маршруту.

Слід зазначити, що задовольнивши відношення всіма обмеженнями цілісності, ми все ж не цілком виключили варіанти ситуації, коли Пролог вибере маршрут, що включає той самий проміжний пункт, кілька разів, тобто їзду по колу. Домогтися виключення зациклення можна шляхом складання списку міст, включених системою в маршрут і заборони пошуку маршрутів для міст, що є в списку. Але для організації цього процесу треба вміти працювати зі списковими структурами, що будуть розглянуті в наступних роботах.