Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Підручник КНУ-4кк11.doc
Скачиваний:
0
Добавлен:
01.05.2025
Размер:
16.18 Mб
Скачать

3.1.1. Концептуальні моделі пс, спс за компонентами

Компонентні системи різного призначення будуються з використанням деяких формальних моделей: графових, онтологічних, семантичних, об’єктно-орієнтованих, системних моделей – GDM, SOA, MDD, MDM, моделей і метамоделей даних і др. В роботі розглядається низка формальних моделей, які пропонуються для подання різних предметних областей, ПС і СПС. Ці моделі сформувались і вдосконалювалися в межах фундаментальних проектів щодо об’єктного і компонентного програмування в ІПС НАНУ (2000–2012) [4, 5]. Моделі ПС і зокрема СПС з компонентів і КПВ програмно реалізовані в інструментально-технологічному комплексі (ІТК) [6] і на фабрики програм КНУ ім.. Тараса Шевченко [7].

Модель предметної області (ПрО)

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

MПрО = {Mo, Мсх, МПС, P, D},

де Mo – множина об’єктів і відношень між ними та свідомістей о змісті функцій і даних об’єктів, с якими вони функціонують.

Мсх – множина загальних характеристик пов’язаних об’єктів через загальні дані та характеристик внутрішнього типа, що притаманні кожному об’єкту і входять до схеми обчислень композицій об’єктів задач ПрО;

МПС – модель програмної системи чи МСПС, які реалізують завдання та функції предметної області ПрО,

Р – множина предикатів з порядку і умов виконання об’єктів за їх функціональними і не функціональними характеристиками моделі властивостей об’єктів Mo, методи яких забезпечують їх програмну реалізацію в ПС,

D – множина даних предметної області, які необхідні для виконання ПС і які можуть зберігатися у базах даних.

Модель програмної системи – МПС

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

Модель програмної системи – ПС дамо у такому визначенні:

МПС = {L, Mf, Ms, Mi, Md},

де L = {L1, L2, …, Lk) – мовні засоби опису функцій чи задач предметної області, одна з мов включає набір операцій (actions) алгебри, щодо дій з реалізації і виконання відповідних програмних компонентів;

Mf – множина функцій моделі ПрО, яка є по сутності моделлю об’єктів ПрО, тобто Mf = {O1, O2,…, Or} цієї ПрО, кожний об’єкт якої трансформується до компонентного коду цієї функції відповідної ПС ПрО;

Ms = {Msin, Msout, …,Msinou} – множина сервісів , що включає моделі передачі вхідних даних Msin, вихідних даних Msout та серверних даних Msinout ПС на сервері Application, базованих на системних сервісах (Common Facility Services) операційного середовища з механізмами компонентів – брокера, монітора, сервісного контракту IContract WСF тощо;

Mi – множина інтерфейсів в мові IDL з описом вхідних (in) і вихідних параметрів (out) та (inout) КПВ об’єднаного типу для пари зв’язних компонентів в структурі ПС. З практичної точки зору усі загальні типи даних специфікуються як зовнішні дані в паспорті моделі ПрО;

Md – множина даних та метаданих предметної області ПС, які специфіковані в КПВ, як примітивні чи складні фундаментальні типи даних, що є в кожної мові програмування. ПС в МП, а також в модулі посереднику (stub, skeleton) в мові IDL.

Множини Ms та Mi мають перетин по даним in, out, inout, які входять до складу зовнішніх типів даних, які передаються по мережі від одного компонентного об’єкту до іншого, що розташованій на сервері Application, після їх обчислень результати повертаються компоненту, що звернувся з запитом чи протоколом..

Модель сімейства програм (СПС)

Сімейство програмних систем (СПС) – це сукупність ПС, які визначаються спільною множиною понять та множиною спеціальних понять і характеристик, що притаманні кожному члену цього сімейства з реалізації деякої ПрО.

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

Модель СПС задамо у вигляді:

МСПС = {{МПС1, МПС2, …, МПСk }, {Mgf, Msf ={Msf1, Msf2, …, Msfk}, Mi, Мd},

де МПС1, МПС2 , …, МПСk – множина членів сімейства ПС;

Mgf – множина зовнішніх характеристик предметної області чи властивості загального типу, що визначають загальну термінологію та властивості усіх ПС сімейства;

Msf ={Msf1, Msf2, …, Msfr} – множина внутрішніх характеристик кожного окремого члена cімейства, поданого моделлю ПС ПСi ) тобто Msf1 для МПС1 ,…, Msfr для МПСk;

Mi – множина загальних інтерфейсів СПС, що подаються мовою IDL;

Мd = {Мd1, Мd2, …, Мdk} – множина даних відповідно для кожного члена ПС.

Монітор чи брокер запитів керує функціями ПрО, відправляє за протоколами типа RPC, RMI, Icontract дані, що специфіковані у інтерфейсному посереднику (stub, skeleton) у IDL чи API моделі клієнт-сервер.

Компонентна модель ПС – CМ

Під компонентним програмуванням розуміється метод створення ПС, заснований на застосуванні концепцій композиції (збирання) на всіх етапах ЖЦ, де базовим елементом композиції є компонент. Компоненти поділені на такі групи:

– прості компоненти, що реалізують деяку функцію ПрО;

– готові компоненти (наприклад, beans–компоненти у мові Lava);

– складні компоненти (каркас, патерни тощо) для групування компонентів;

– інтерфейс з описом параметрів для встановлення зв’язку між різними компонентами між собою;

– сервіси, що підтримують різні системні дії з організації передачі параметрів і даних, представлених в інтерфейсі чи контракті;

– засоби розгортання компонентів в деякому гетерогенному середовищі.

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

– формалізації та впорядкованості процесу розробки окремих компонентів та систем з КПВ зі зменшенням часу розробки і збільшення якості та надійності складних систем;

– механізмів опису інтерфейсів компонентів для їх виконання у інтегрованому середовищі з використанням загальносистемних сервісів та ін.;

– спрощення процесів побудови ПС за моделлю з компонентів та методів їх конфігурування чи збирання у різні складні структури для їх виконання.

Компонентна модель ПС – це таке абстрактне уявлення ПС, що конструюється з компонентів, які є елементами уявлень і їм зіставлені реальні функції чи методи об’єктів ПрО, що забезпечують реалізацію функціональності та виконання інших не функціональних вимог щодо ПрО. Для однієї і тієї ж ПС може існувати безліч її компонентних моделей в залежності від концепцій проектування і використовуваного компонентного підходу. Моделі компонентної моделі (Component Model – СМ) відповідає цілком і повністю структура моделей МПС чи МПС з тою різницією, що тут використовуються програмні компоненти і КПВ, якяк готові ресурси різного призначення. Вони стали капіталоємкими продуктами і є об’єктами комерційного програмування, (наприклад, компоненти загальної бібліотеки математичних задач MatLab), що застосовуються при глобальних обчисленнях у середовищах Grid i Cloud Computing.

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

                  N

Нехай  Ai – множина інтерфейсів за контрактами компонентів чи програм, що

i=1

визначають її визначають її функціональність. Кожному Ai який описує контракт як клієнт-серверну взаємодію з відповідними методами і структурами даних. Кожний інтерфейс має опис інтерфейсних даних –In, Out і Inout, які будемо називати відповідно визначальним поданням інтерфейсу (поняття – вхідний, вихідний та проміжний інтерфейс). Ini визначає умови і мету контракту з боку клієнта, Outi задає реалізацію компоненту з боку сервера, а Inout – властивості інтерфейсів Ini і Outi

Визначені інтерфейсів Ai для компонентів моделі СМ можуть групуватися у різні поєднання з урахуванням семантики характеристик загального і внутрішнього типів, що визначені для моделі системи і компонентів і входять до складу компонентної моделі.

Довільна сукупність інтерфейсів Ini, Outj, Inoutij, де i  J, може не входять в кожну таку сукупність і одночасно визначати пари програмних компонентів приїх збиранні в складну структуру.

Для кожної отриманої сукупності пар Ci Iv = {Ci, Iv, OutJ, Inoutij} створюється модель компонента або шаблон, який містить деяку множину параметрів, які визначають і реалізують уявлення інтерфейсів. За цими уявленнями надалі здійснюється зіставлення шаблонів і інтерфейсів реальних компонентів.

В результаті операцій групування виходить множина пар Ci Iv { яке і буде зватися контрактом компонентної моделі ПС. Для однієї і тієї ж програми існує множина таких моделей, які визначаються множинами контрактів (або інтерфейсів) зі способами розбиття на шаблони компонентів для послідовного їх виконання.

Загальне визначення алгебри компонентів

Нехай Х – множина об'єктів x, де xi X – довільний об'єкт деякої ПрО, якій завдає функцію ПрО і пов'язаний з іншими об’єктами відношенням зв’язку. Цієї множині відповідає множина програмних компонентів C (C X.). Кожен компонент реалізує функцію і характеризується деякими притаманними йому властивостями (наприклад, варіантність, змінюваність тощо), які завдаються в їх інтерфейсах.

Властивості чи характеристики компонентів завдаються загальними і особистими типами та їх предикатами P1, , P2, , ..., Pk з умовами виконання компонентів з множини xi.  X можливі деякі операції, результати виконання яких також є елементи множини X. Тривіальними прикладами таких операцій можуть бути – об'єднання кількох об'єктів в один або декомпозиція деякого програмного компоненту на окремі частини

Нехай  R i – множина операцій над об'єктами з X. Кожна операція має власну арність в залежності від її семантики. В цілому існують операції, які задаються на подмножествах з X, а також можна створювати підмножину операцій (наприклад, попередні операції об'єднання та декомпозиції).

Серед множини операцій розглядаються ті, які зберігають властивості компонентів і їх результатів. Ці операції R1, R2 ,..., Rm виконуються над будь-якими компонентами c1 , , c2 ,..., сm C з урахуванням арності операції Ri та результату таких двох видів:

c1 , , c2 ,..., сm C).

Множина C та операції R1, R2.,.., Rm визначатимуть алгебру компонентів. Прикладами реальних операцій над компонентами можуть бути операції розширення інтерфейсів і факторингу для сукупності нових компонентів за іншими інтерфейсами, але з такою ж функціональністю. В розділі 2.4 подано компонентні алгебри (внутрішня і зовнішня). Для кожної алгебри відповідає властивостям компонентів та операцій, формально визначених для множини компонентів і які застосовуються в конкретної теорії компонентного програмування щодо конструювання програм і систем з готових КПВ.

Визначення загальної множини компонентів

Множина компонентів C, розглянуте вище, є математичною абстракцією. У реальному випадку мається на увазі деяка множина реальних компонентів з сі  C. Застосувавши до цієї множини операції R1, R2.,.., Rm, можна отримати множину, яку будемо називати замиканням множини С’. Цей термін обраний для того, щоб підкреслити, що С’ є максимально можливою множиною компонентів, які можна отримати на основі вибраних компонентів з множини C, відповідно до сі C. У реальних процесах конструювання програм розглядається множина компонентів C (або C’), але при цьому враховується, що для нього справедливі всі положення відповідної компонентної алгебри при конкретної побудови компонентних. ПС, виконаної практично в ІТК [ ].