Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
NikitchenkoNEWNEW.doc
Скачиваний:
26
Добавлен:
08.11.2019
Размер:
2.99 Mб
Скачать

3.4. Рівні конкретизації програмних систем

Розгляд рівнів почнемо з конкретизації поняття даного.

Рівні конкретизації даних. Як відзначалося раніше, треба будувати програмні поняття різних рівнів абстракції. Це стосується і даних. У цьому розділі розглянемо конкретизації даних, які фактично індуковані розвитком поняття даного в програмній пентаді (дане – ім'я – дескрипція). Інші конкретизації розглянемо пізніше. Програмна пентада фактично вказує на три рівні розгляду даних. Перший рівень – абстрактний, коли ніякі властивості даних не виділяються і дані розглядаються як елементи деякої абстрактної множини. Другий рівень визначається тим, що виділяються деякі специфічні дані. Звичайно такі дані застосовуються як логічні константи, тому назвемо другий рівень булевим рівнем. Нарешті, на третьому рівні є можливість виділяти компоненти даних. З огляду на те, що таке виділення компонент звичайно робиться за допомогою відношень іменування (номінації), назвемо третій рівень номінативним рівнем. Можна також охарактеризувати дані на абстрактному рівні як чорні (непрозорі) скриньки, константи булевого рівня – як білі (прозорі) скриньки, а дані номінативного рівня – як сірі (частково прозорі) скриньки.

Три виділені рівні приводять до трьох класів систем даних. Абстрактна система даних (визначена раніше) – ADS =<D>. Система даних булевого рівня в загальному випадку має вигляд BDS =<D, c1, c2, ...> , де c1, c2, ... – деякі виділені елементи (константи) з D. Можна виділити три типи систем: перед-булеву систему <D, true>, булеву систему <D, true, false> та пост-булеву систему <D, c 1, ..., ck>.

На номінативному рівні дані розглядаються як номінативні дані. Клас ND інфінітарних номінативних даних будується індуктивно на основі деяких множин імен V і значень W:

1) ND(0) =W,

2) ND(i+1)=V ND(i), i.

Тоді ND = (i) .

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

Система даних номінативного рівня може бути задана як кортеж NDS=<V, W, D>, де DND.

Зазначимо, що вищенаведене індуктивне визначення номінативних даних може бути подане у вигляді наступного рекурсивного визначення: ND=W(V ND).

Ці визначення допускають інфінітарні (нескінченні) номінативні дані. У програмуванні клас номінативних даних обмежується класом ієрархічно побудованих скінченних реляційних відображень. Тому виділимо наступні основні класи номінативних даних:

  • однозначні номінативні дані (скінченні однозначні відображення), які називаються іменними даними;

  • багатозначні номінативні дані (скінченні багатозначні реляційні відображення), які називаються просто номінативними даними.

Іменні дані дозволяють формалізувати структури даних, які використовуються у програмуванні та характеризуються однозначністю іменування своїх компонент. Це такі структури даних, як записи, масиви, файли, реляції тощо. Номінативні дані дозволяють задавати структури даних, яким властива неоднозначність іменування своїх компонент, такі як множини, перед множини, мультимножини тощо. Наприклад, множину вигляду {s1, s2, ..., sn} можна представити номінативним даним [s1, s2, ..., sn], де 1 обрано як стандартне ім’я елементів множини. Для роботи з такими даними повинні бути введені спеціальні функції, які відображають рівень абстракції даних. Важливо відзначити, що всі такі функції є конкретизаціями абстрактних функцій опрацювання номінативних даних, що істотно зменшує загальне число функцій та спрощує їх дослідження. Зазначимо також, що розгляд даних як спеціальних функцій має давні традиції у програмуванні.

Рівні конкретизації функцій. Кожен із рівнів конкретизації даних індукує відповідний рівень розгляду функцій. Абстрактному рівню відповідає абстрактний (нетипізований) клас функцій з D у D. Булевому рівню відповідають такі класи, як часткові характеристичні функції – часткові відображення на D, що приймають лише значення true (перед-булевий рівень), предикати – часткові відображення з D у Bool (булевий рівень), і часткові скінченнозначні відображення з D у {c 1, ..., ck} (пост-булевий рівень). Природно, що найбільш багаті класи функцій можна виділити на номінативному рівні. Фактично такі класи визначають класи функцій над різними структурами даних. У цьому випадку системи функцій конкретизуються як типізовані системи. Серед функцій номінативного рівня основними будуть різні типізовані функції іменування, розіменування, накладення, видалення компонент тощо.

Рівні конкретизації композицій. Як і в попередньому випадку, доцільно виділити три рівні композицій. Обмежимося тут розглядом композицій як однозначних відображень. У цьому випадку на абстрактному рівні можна виділити лише одну нетривіальну композицію – послідовне виконання  (яку звичайно називають функціональною композицією). Однак цього вже досить, щоб почати розвиток теорії категорій, для якої множення функцій є основною досліджуваною операцією. На булевому рівні можна додатково визначити такі композиції, як умовні оператори та цикли різних видів. Тому до булевого рівня можна віднести системи структурного програмування та системи алгоритмічних алгебр. Найбільш багатий композиціями номінативний рівень. Тут визначають наступні основні засоби конструювання програм: різні суперпозиції, розіменування, присвоювання тощо. Зазначимо, що введене поняття композиційної системи дозволяє дати опис повних класів композицій на різних рівнях абстракції, тобто описати всі композиції відповідного рівня.

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

Інтеграція композиційних і дескриптивних систем номінативного рівня за допомогою відображень денотації дозволяє дати цілісний опис різноманітних мов програмування і баз даних. Такі композиційно-дескриптивні системи номінативного рівня будемо називати композиційно-номінативними системами. Ці системи дозволяють також адекватно описувати семантику різних логічних мов і мов специфікацій прикладних областей.

Висновки

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

Додаткову інформацію про програмні системи можна знайти у [2, 4, 8, 15].

Контрольні питання

  1. Розкрийте зміст принципу теоретико-функціональної формалізації поняття програми.

  2. Визначте різні класи функцій.

  3. Визначте програмні системи різного рівня абстракції.

  4. Дайте визначення класу номінативних даних.

Соседние файлы в предмете [НЕСОРТИРОВАННОЕ]