Documente Academic
Documente Profesional
Documente Cultură
INFORMATICĂ
MANAGERIALĂ ŞI
DE GESTIUNE
ANUL III Semestrul 2
INTRODUCERE
Modele de procese de afaceri sunt importante în diferite etape ale ciclului de viață al
BPM. Înainte de a începe pentru modelarea unui proces, este esențial să înțelegem de ce este
nevoie de modelare. Modelele pe care le producem vor arata diferit în funcție de motivul pentru
care se creează modelul, în primul rând. Există multe motive pentru modelarea unui proces.
Primul dintre ele este pur și simplu de a
înțelege procesul și de a împărtăși înțelegerea noastră cu cei care sunt implicați în procesul
respectiv în viaţa de zi cu zi. Într-adevăr, participanții la un proces de obicei efectuează activităţi
detaliate/specializate din respectivul proces, astfel încât acestea nu se confruntă cu
complexitatea întregului proces. Prin urmare, procesul de modelare îi ajută să înțeleagă mai bine
procesul în scopul de a identifica și pentru a preveni problemele de execuţie ale acestuia. Acest
pas spre o înțelegere aprofundată este prima condiție care trebuie îndeplinită pentru a efectua
analize de proces, re-design sau automatizare.
În acest suport de curs sunt prezentate elementele esenţiale necesare familiarizării cu
ingredientele de bază ale procesului de modelarea folosind limbajul Business Process Modeling
Notation (BPMN). Cu aceste concepte, veţi fi capabili să produceţi modele de procese de afaceri
care surprind relațiile temporale și logice simple, între activități, obiecte, resurse (de ex. angajaţi),
respectiv între date. În primul rând, vom descrie concepte esențiale legate de modelele de
proces, și anume modul în care modelele de proces se leagă de instanţele de proces. Apoi, vom
explica principalele patru blocuri structurale de ramificare și fuzionare care pot fi folosite în
modelele de proces. Acestea definesc decizii exclusive, execuția în paralel, deciziile inclusive și
repetițiile. În cele din urmă, vom acoperi artefactele de informații/date respectiv resursele
implicat într-un proces.
Un limbaj de modelare este format din trei părți: sintaxa, semantica, și notația. Sintaxa
oferă un set de elemente de modelare și un set de reguli care guvernează modul în care pot fi
combinate aceste elemente. Semantica leagă elementele sintactice și descrierile lor textuale într-
un înţeles clar, fără ambiguităţi. Notaţia definește un set de simboluri grafice pentru vizualizarea
elementelor. De exemplu, sintaxa BPMN include activități, evenimente, gateway-uri, și secvența
activităţilor. Un exemplu de reguli sintactice BPMN este faptul că evenimentele de tip start au
numai secvențe de ieșire în timp ce evenimentele finale au doar secvențe de intrare. Semantica
BPMN descrie ce fel de comportament este reprezentat prin diferite elemente. În esență, aceasta
se referă la întrebarea cum elementelor pot fi executate în ceea ce privește fluxul de activităţi.
De exemplu, un element care denotă o sincronizare a unor ramuri paralele ale procesului impune
așteptarea până când fiecare din ramurile de intrare sunt finalizate, înainte de a permite trecerea
la ramurile de ieșire din acesta. Un exemplu de notație BPMN este utilizarea unor dreptunghiuri
cu marginile rotunjite pentru a reprezenta activitățile procesului.
În acest suport de curs am prezentat elementele de bază ale procesului de modelare prin
limbajul BPMN. Alte limbaje răspândite care pot fi utilizate pentru a modela procese de afaceri
sunt Diagramele de Activităţi UML (UML AD), Event-driven Process Chains (EPC) și Web Services
Business Process Execution Language (WS-BPEL).
Diagramele UML AD sunt un alt standard OMG (Object Management Group). Ele sunt
aplicate în principal în ingineria software, unde pot fi folosite pentru a descrie comportamentul
software și pot fi legate de alte tipuri de diagrame UML (de exemplu, diagrame de clase, pentru
a genera automat cod software). Diagramele UML AD oferă un subset al elementelor de
modelare prezente în BPMN. De exemplu, construcţiile de tip OR-join nu sunt acceptate.
Notaţia EPC a fost dezvoltată inițial pentru proiectarea proceselor de referință incluse în
SAP R/3. A fost adoptată pe scară largă de către diverse organizații, atunci când a devenit limba
de modelare de bază a setului de instrumente ARIS. Mai târziu, au fost utilizate de către alți
furnizori pentru proiectarea de modele de referință, independent de SAP, cum ar fi ITIL și SCOR.
Notaţia EPC include elemente de modelare corespunzătoare activităților din BPMN, precum şi
pentru gateway-uri AND, XOR și OR, respectiv pentru evenimente și obiecte de date.
WS - BPEL (BPEL pe scurt), versiunea 2.0, este un standard al Organizației pentru
Promovarea Standardelor Referitoare la Informația Structurată (OASIS). BPEL este un limbaj de
execuție a modelelor de procese care se bazează tehnologia serviciilor Web pentru a realiza o
comunicare între procese. O ‚traducere’ din BPMN în BPEL este inclusă în specificația BPMN. Cu
toate acestea, această mapare nu este completă deoarece BPEL oferă un set restrâns de
construcții comparativ cu BPMN, precum și pentru că este în esență un limbaj orientat-bloc, în
timp ce BPMN este orientat-graf. BPEL este structurat în blocuri care trebuie să fie imbricate în
mod corespunzător și nu se pot suprapune. Un bloc este format dintr-un singur nod de intrare, și
un singur nod de ieșire (care corespunde cu tipul de nod de intrare și colectează toate ramurile
de ieșire de la nodul de intrare). De exemplu, în cazul în care nodul de intrare este un AND-split,
nodul de ieșire trebuie să fie un AND-join. Mai mult decât atât, BPEL nu este dotat cu un standard
de notație, din moment ce acest lucru a fost considerat a fi în afara domeniului de aplicare de
către OASIS, deși diferiţii vânzători oferă notații proprietare personalizate pentru acest limbaj. În
timp ce BPMN 1.2 a avut scopul de a fi omologul conceptual al BPEL, și mapările au fost create
pentru a trece de la una la alta. Însă, BPMN 2.0 poate fi folosit singur pentru a specifica procesele
executabile. Astfel, BPMN 2.0 poate să înlocuiască BPEL în acest sens.
Alte limbaje de modelare a proceselor provin din eforturile de cercetare. Două dintre ele
sunt Workflow Nets și Yet Another Workflow Language (YAWL). Workflow Nets sunt o extensie a
rețelelor Petri pentru modelarea proceselor de afaceri. Sintaxa lor este în mod intenționat simplă
și se învârte în jurul a două elemente: place-uri și tranziții. Place-urile corespund aproximativ
evenimentelor BPMN, în timp ce tranziţiile corespund activităților BPMN.
YAWL este un succesor al Workflow Nets, la care se adaugă construcții specifice pentru a
face posibilă reprezentarea comportamentului OR-join, activităților multi-instanțe, sub-
proceselor și regiunilor de anulare. YAWL păstrează simplitatea și intuitivitatea Workflow Nets,
deși oferă un limbaj mult mai expresiv.
O comparație dintre limbajele menţionate mai sus, în ceea ce privește expresivitatea lor pentru
reprezentarea secvenţelor de activităţi, a perspectivelor de date și de resurse, pot fi găsite pe
website-ul Workflow Patterns [www.workflowpatterns.org]. În timp, această inițiativă a colectat
un depozit de şabloane de procese observate des în practică şi implementate în cadrul unor
aplicaţii dedicate modelării proceselor de afaceri.
Cu peste 100 de simboluri, BPMN este un limbaj destul de complex. Dar numărul mare de
simboluri nu este un motiv de panică, deoarece o mică parte din acestea acoperă nevoile de
modelare a marii majorităţi a utilizatorilor. După ce stăpâniţi acest nucleu de simboluri BPMN,
restul elementelor vor fi învățate natural, din practică. Deci, în loc să descriem în detaliu fiecare
simbol BPMN, vom introduce simbolurile și conceptele BPMN treptat, prin intermediul unor
exemple.
Fig. 1 – Diagrama BPMN a unui proces simplu pentru onorarea unei comenzi de cumpărare
În acest capitol, sunt prezentate simbolurile de bază ale BPMN. Un proces de afaceri
implică evenimente şi activităţi. Evenimentele reprezintă lucruri care se întâmplă instantaneu (de
exemplu, o factură a fost primită) în timp ce activitățile reprezintă unități de lucru care au o
durată (de exemplu, plata unei facturi). De asemenea, un proces înseamnă că evenimentele și
activitățile sunt în mod logic legate. Forma cea mai elementară de relaţie între două elemente
(fie ele evenimente sau activităţi) este secvenţa, ceea ce implică faptul că un eveniment sau
activitatea A este urmat de un alt eveniment sau activitate B. Prin urmare, trei concepte de bază
ale BPMN sunt evenimentele, activităţile, și arcele. Evenimentele sunt reprezentate de cercuri,
activități de dreptunghiuri rotunjite, și arcele (numite ‚fluxuri de secvenţă’ în BPMN) sunt
reprezentate de săgeți.
Exemplu 3.1 Fig. 1 prezintă modul in care este modelată folosind notaţia BPMN o simplă
secvență de activități aferentă unei comenzi de cumpărare. Acest proces începe ori de câte ori
un ordin de cumpărare a fost primit de la un client. Prima activitate care se desfășoară este
‚confirmă comandă’. Apoi, este înregistrată adresa de destinație, astfel încât produsul să poată fi
livrat clientului. Ulterior, factura este emisă. După ce suma facturii este încasată, ordinul este
arhivat, finalizându-se astfel procesul.
Din exemplul de mai sus se observă că cele două evenimente (de start şi de stop) sunt descrise
cu două simboluri ușor diferite. Se folosesc cercuri cu o margine subțire pentru a reprezenta
evenimente de pornire și cercuri, cu o margine groasă pentru a reprezenta evenimentele finale.
Evenimentele de început şi cele finale au un rol important într-un model de proces: evenimentul
de start indică momentul când instanțele procesului încep, în timp ce evenimentul final indică
atunci când instanţa (denumită şi caz) este completă. De exemplu, o nouă instanță (sau un nou
caz) a(l) procesului de onorare a comenzilor este declanșată ori de câte ori o comandă de achiziție
este primită, și se finalizează atunci când comanda este onorată.
Pentru a modela relația dintre două sau mai multe activități alternative, cum ar fi în cazul
aprobării sau respingerii unei cereri, se foloseşte un gateway de tip split exclusiv (denumit şi XOR-
split). Se foloseşte un gateway de tip join exclusiv (denumit şi XOR-join) pentru a îmbina două
sau mai multe ramuri alternative, care au fost în prealabil bifurcate cu un XOR-split. Un gateway
XOR este indicat în BPMN printr-un diamant gol sau printr-un diamant care conţine în interior un
"X". În toate exemplele care urmează de acum înainte, vom folosi mereu "X" în interiorul unui
diamant pentru a marca un gateway de tip XOR-split sau XOR-join.
Fig. 3 – Exemplu de folosire a unui gateway exclusiv
Atunci când două sau mai multe activități nu au dependențe de ordine de la una la alta
(adică o activitate nu are nevoie să fie urmată de alta, nici nu o exclude pe cealaltă) ele pot fi
executate simultan, sau în paralel. O poartă paralelă (AND gateway) este folosit pentru a modela
acest raport special. În mod specific, vom folosi un AND-split pentru a modela executarea
paralelă a două sau mai multe ramuri, și un AND-join pentru a sincroniza execuția de pe două sau
mai multe ramuri paralele. Un Gateway de tip AND este descris ca un diamant care conţine un
semn "+".
Exemplul 3 (Verificarea de securitate la un aeroport): După ce cartea de îmbarcare a fost
emisă, pasagerii trebuie să se prezinte la controlul de securitate. Aici se realizează controlul
personal cât şi cel al bagajelor de mână. După aceea, pasagerii pot merge la poarta de îmbarcare.
Acest proces constă din patru activități. Modelul începe cu activitatea "Mergi la
verificarea de securitate" continuă cu activităţile „Realizare verificare personală”, „Realizare
verificare bagaje” și se termină cu activitatea "Mergi la poarta de plecare". Aceste două activități
au o dependență clară: un pasager poate merge la poarta de plecare doar după efectuarea
ambelor controale de securitate. După prima activitate, iar înainte de ultima nea aflăm în situaţia
de a efectua două activități care pot fi executate în orice ordine, adică care nu depind unele de
altele: „Realizare verificare personală”, respectiv „Realizare verificare bagaje”. Pentru a modela
această situație, vom folosi un AND-split care leagă activitatea "Mergi la verificarea de securitate"
de cele două activități de verificare. De asemenea, vom folosi un AND-join care sincronizează cele
două ramuri cu activităţile de verificare astfel încât activitatea "Mergi la poarta de plecare" să nu
se poată executa înaintea finalizării celor două verificări (vezi Fig. 4).
În al doilea rând, cele două secvențe "Preia adresa de expediere" - "Expediază produsul"
și "Emite factură" - "Înregistrează plata", pot fi efectuate în mod independent una de cealaltă. Ca
urmare ele sunt incluse într-un bloc între un AND-split și un AND-join. În realitate, aceste două
seturi de activități sunt de obicei executate de resurse diferite din cadrul organizaţiei (de ex. un
gestionar pentru expediere și un ofițer financiar pentru factură) și, astfel, pot fi executate în
paralel. Remarcaţi cuvântul "între timp", din descrierea procesului, deoarece acesta indică faptul
că două sau mai multe activități pot fi efectuate în același timp.
Să comparăm versiunea din Fig. 5 a procesului de onorare a comenzilor cu Fig. 1 în ceea
ce privește evenimentele. Noua versiune dispune de două evenimente de sfârşit în timp ce prima
versiune dispune de un singur eveniment de sfârșit. Într-un model BPMN putem avea mai multe
evenimente finale, fiecare capturând un rezultat diferit al procesului (de exemplu, comandă
confirmată faţă de comandă respinsă). BPMN adoptă așa-numita terminare semantică implicită,
ceea ce înseamnă că o instanță de proces se finalizează numai atunci când fiecare token care
curge prin model atinge un eveniment terminal. În mod similar, putem avea mai multe
evenimente de start într-un model BPMN, fiecare eveniment capturează un declanșator diferit
pentru a începe o instanţă a procesului. De exemplu, am putea începe procesul de onorare a
comenzilor, fie atunci când o nouă comandă de achiziție este primită fie atunci când o comandă
revizuită este retrimisă de un client. În cazul în care o comandă revizuită este retrimisă, se pot
regăsi în primul rând detaliile comenzii precedente din baza de date de comenzi, și apoi continua
cu restul procesului. Această variantă a modelului de onorare a comenzilor este prezentat în Fig.
6. O instanţă a acestui model de proces este declanșată de primul eveniment care apare
(remarcaţi utilizarea unui XOR-join pentru a fuziona ramuri care provin din două evenimente de
pornire).
Fig. 6 – O variantă a procesului de onorarea a unei comenzi, cu două evenimente declanşatoare diferite
Există două situații în care un gateway poate fi omis. Un XOR-join poate fi omis înainte de
o activitate sau un eveniment. În acest caz, arcele de intrare în XOR-join sunt conectate direct la
activitate sau la eveniment. Un AND-split poate fi, de asemenea, omis, atunci când urmează după
o activitate sau un eveniment. În acest caz, arcele de ieșire ale AND-split-ului vor porni direct din
activitatea sau evenimentul precedent.
Câteodată e nevoie să se execute una sau mai multe dintre ramurile care pleacă dintr-un
split. Exemplul 5 (Procesul de distribuire a mărfurilor): O companie are două depozite care
stochează diferite produse: unul la Amsterdam și altul la Hamburg. Când o comandă este primită,
acesta este distribuită din aceste depozite. Dacă unele dintre produsele comandate sunt stocate
în Amsterdam, o sub-comandă este trimisă acolo, şi reciproc, în cazul în care unele dintre
produsele comandate sunt stocate în Hamburg, o sub-comandă este trimisă acolo. După aceea,
comanda este înregistrată și procesul se termină.
Putem modela scenariul de mai sus, folosind o combinație de gateway-uri AND şi/sau
XOR? Răspunsul este „da, cu unele probleme”. Figurile 7 și 8 arată două soluții posibile. În primul,
vom folosi un XOR-split cu trei ramuri alternative: una urmată în cazul în care ordinul conține
doar produse aflate în Amsterdam (unde sub-comanda este transmisă la depozitul de la
Amsterdam), o alta urmată în cazul în care comanda conține doar produse aflate în Hamburg (în
mod similar, în această ramură sub-comanda este transmisă la depozitul Hamburg), și o a treia
ramură care trebuie urmată în cazul în care comanda conține produse din ambele depozite (caz
în care sub-comenzile sunt transmise către ambele depozite). Aceste trei ramuri converg într-un
XOR-join care duce la înregistrarea comenzii.
Fig. 7 – Prima încercare de a modela o decizie inclusivă
În timp ce acest model surprinde scenariul nostru corect, diagrama rezultată este
oarecum complicată, din moment ce avem nevoie de duplicate pentru cele două activități de
transmitere a sub-comenzilor către cele două depozitele. Și dacă am fi avut mai mult de două
depozite, numărul de activități duplicat ar crește. De exemplu, dacă am avea trei depozite, am
avea nevoie de un XOR-split, cu șapte brațe de ieșire, și fiecare activitate ar trebui să fie duplicată
de patru ori. În mod clar această soluție nu este scalabilă.
În cea de a doua soluție folosim un AND-split, cu două arce de ieșire, fiecare ducând la
câte un XOR-split cu două ramuri alternative. Una este urmată in cazul în care comanda conține
produse din Amsterdam/Hamburg, caz în care activitatea de transmitere a sub-comenzii se
efectuează; cealaltă ramură este urmată în cazul în care ordinul nu conține nici un produs din
Amsterdam/Hamburg, caz în care nu se face nimic până la XOR-join-ul care îmbină cele două
ramuri alternative. Apoi, un AND-join unește cele două ramuri paralele și procesul se termină
prin înregistrarea comenzii.
Care este problema cu această a doua soluție? Scenariul din exemplu permite trei cazuri:
produsele sunt doar în Amsterdam, doar în Hamburg, sau în ambele depozite. Dar această soluție
permite mai mult cu un caz: atunci când produsele nu sunt în nici unul din cele două depozite.
Apare acest caz, atunci când cele două ramuri goale ale celor două XOR-split-uri sunt urmate,
astfel neexecutându-se nici o activitate între "Verifică produsele comandate" și "Înregistrează
comanda". Astfel această soluție, în ciuda faptului că este mai compactă decât prima, este
greșită.
Pentru a modela situațiile în care o decizie poate conduce la alegerea uneia sau a mai
multor opțiuni, avem nevoie să luăm o decizie inclusivă (OR). Un OR-split este similar cu XOR-
split, dar condițiile de pe ramurile de ieșire nu trebuie să se excludă reciproc (adică mai mult de
una dintre ele poate fi adevărat în același timp). Când execuţia procesului ajunge la un OR-split
se pot urma una sau mai multe ramuri de ieşire, în funcție de care condiții sunt adevărate. În
ceea ce privește semantica token-urilor, acest lucru înseamnă că OR-split-ul consumă un token
de-a lungul arcului de intrare și generează un număr variabil de token-uri, echivalent cu numărul
de condiții de ieșire care sunt adevărate. Acest număr poate fi cel puțin unu și cel mult numărul
total ramuri de ieșire din OR-split. Similar cu un XOR-split, un OR-split poate fi, de asemenea,
urmat de un arc de ieşire prestabilit (care este urmat numai atunci când toate celelalte condiții
sunt evaluate ca false).
Fig. 10 – De ce tip ar trebui sa fie join-ul astfel încât instanţele procesului sa se execute corect?
În acest capitol, aţi învățat cum să combinaţi activități, evenimente, și gateway-uri pentru a crea
un model de bază. Pentru fiecare element enumerat, am arătat care este reprezentarea grafică,
am introdus regulile pentru combinarea cu alte elemente de modelare și am explicat
comportamentul în termeni de reguli simbolice. Toate aceste aspecte se încadrează în termenul
generic de „componente ale unui limbaj de modelare”.
Exerciţii recapitulative:
2.1. Creați un model BPMN pe baza următoarei descrieri: Odată ce o cerere de împrumut este
primită de către o bancă, și înainte de a începe evaluarea ei, cererea trebuie să fie verificată dacă
a fost completată corect. În cazul în care cererea este incompletă/incorect completată, acesta
este returnată solicitantului. Acesta poate completa informațiile lipsă și trimite înapoi cererea la
bancă. Acest proces se repetă până când se constată că cererea este completată corespunzător.
2.2. Creaţi un model BPMN pe baza următoarei descrieri: O cerere de împrumut este aprobată
dacă trece două controale: (i) de evaluare a riscului de credit al solicitantului, realizată automat
de către un sistem, și (ii) evaluarea proprietății pentru care împrumutul a fost solicitat, efectuată
de către un evaluator. Evaluarea riscurilor necesită o verificare a istoricului de creditare a
solicitantului, care este efectuată de către un ofițer financiar. După ce atât evaluarea riscului de
credit cât și evaluarea bunurilor au fost efectuate, un ofițer de credit poate evalua eligibilitatea
solicitantului. În cazul în care solicitantul nu este eligibil, cererea este respinsă, în caz contrar
documentele de credit sunt pregătite și transmise solicitantului.
Capitol 3: Perspectiva de date a modelelor de procese
Adesea datele produse într-o activitate coincid cu cele de care e nevoie ca intrare într-o activitate
ulterioară. De exemplu, odată ce au fost obținute Materii prime (obiectul de date „Raw
materials”), acestea sunt folosite de activitatea "Manufacture product", pentru a crea un produs.
Produsele, la rândul lor, sunt ambalate și trimise clientului în cadrul activității "Ship product". În
mod eficient, obiecte de date ne permit să modelăm fluxul de informații între activitățile din
proces. Țineți minte, cu toate acestea, că obiecte de date și asociațiile acestora cu activități nu
pot înlocui secvența de flux a activităților. Cu alte cuvinte, chiar dacă un obiect este trecut de la
o activitate la A la o activitate B, avem încă nevoie pentru a modela secvența de activități A -> B.
O notație prescurtată pentru trecerea unui obiect dintr-o activitate în alta este prin conectarea
directă a obiectelor de date direct cu arcul care reprezintă fluxul de secvență între două activități
consecutive, printr-o asociație neorientată. A se vedea, de exemplu, modul în care e modelată
asocierea obiectului de date „Shipment address” cu arcul care unește activitățile "Get shipment
address" și "Ship product". Aceasta este o prescurtare care indică faptul că adresa de expediere
este o ieșire a activității "Get shipment address" și o intrare a activității „Ship product".
Uneori, am putea avea nevoie să reprezentăm starea unui obiect de date. De exemplu,
activitatea de confirmare a comenzii "Confirm order" are un ordin de cumpărare ca intrare, și
returnează tot un ordin de cumpărare dar în starea ‚confirmat’. În mod similar, activitatea
"Receive payment" are ca intrare tot o comandă de cumpărare ‚confirmată’ și o transformă într-
una ‚plătită’. Un obiect poate trece printr-o serie de stări. De exemplu, o factură este prima dată
"deschisă", apoi "aprobată" sau "respinsă" și în final "arhivată". Indicarea stării obiectelor de date
este opțională. Putem face acest lucru prin adăugarea numele stării între paranteze pătrate, de
exemplu, "Comandă [confirmată]", "produs [ambalat]".
Un depozit de date este un loc care conține obiecte de date care trebuie să fie persistente
(să existe si după ce o instanță a procesului s-a finalizat). De exemplu, o bază de date pentru date
electronice sau un dulap de arhivare pentru cele fizice. Activitățile din proces pot citi/scrie
obiecte de date din/în baze de date. De exemplu, activitatea "Verificați disponibilitate stoc" preia
valoarea stocului pentru produsul comandat de la baza de date, care conține informații cu
valoarea stocurilor pentru diverse produse. În mod similar, activitatea "Verifică disponibilitate
materii prime", consultă catalogul de furnizori pentru a returna care furnizor trebuie contactat.
Baza de date Warehouse DB sau Supplier Catalog sunt exemple de baze de date în care se
stochează date produse de activități. Un exemplu de depozit de date folosit ca ieșire este baza
de date Orders BD, care este utilizată de activitate "Archive order" pentru a stoca comanda de
cumpărare confirmată. Bazele de date sunt reprezentate ca un cilindru gol (simbolul tipic pentru
o bază de date), cu marginea de sus triplă. Similar cu obiectele de date, acestea sunt conectate
la activități prin intermediul asociațiilor de date.
Întrebare: Afectează perspectiva de date secvenţa de execuţie a activităţilor?
Obiectele de date de intrare sunt necesare pentru o activitate care urmează să fie executată.
Chiar dacă un token este disponibil pe arcul de intrare a acestei activități, ea nu poate fi executată
până când toate obiectele de date de intrare sunt de asemenea disponibile. Un obiect de date
este disponibil în cazul în care acesta a fost creat ca urmare a finalizării unei activități anterioare,
sau pentru că este o intrare a întregului proces (cum ar fi ordinul de cumpărare în exemplu de
mai sus).
Întrebare: Trebuie întotdeauna modelată perspectiva de date?
Obiectele de date ajută cititorul să înțeleagă fluxul de date de la o activitate la alta. Cu toate
acestea, prețul includerii perspectivei de date în model este o complexitate crescută a diagramei.
Astfel, vă sugerăm să le folosiți numai atunci când acestea sunt necesare pentru un anumit scop,
de exemplu, pentru a evidenția potențialele probleme în procesul de analizat sau pentru
automatizare. Uneori, am putea avea nevoie să furnizăm informații suplimentare pentru cititor,
în scopul îmbunătățirii înțelegerii modelului. De exemplu, în procesul de onorare a comenzilor
am putea dori să precizăm că activitatea de expediere a produselor "Ship product" include
ambalarea produsului.
De asemenea, ne-am putea dori să clarificăm ce regulă de afaceri este urmată în cazul
alegerii de materii prime de la furnizori. Astfel de informații suplimentare pot fi furnizate prin
intermediul adnotărilor textuale. O adnotare este desenată ca un dreptunghi deschis care
conține un text, și care este legat de un element al modelului printr-o linie punctată (denumită
tot asociere) - vezi Fig. 13 pentru un exemplu. Adnotări de text nu poartă nici o semantică, prin
urmare, ele nu afectează fluxul de token-uri prin modelul de proces.
Exerciţii recapitulative:
3.1. Alăturaţi cele patru fragmente de modele de proces create la problemele anterioare pentru
a constitui perspectiva completă asupra procesului de evaluare a unei cereri de creditare.
Sugestie: examinaţi cu atenţie evenimentele start şi stop ale fragmentelor, pentru a putea
determina modul în care acestea se leagă între ele.
3.2. Îmbogăţiţi modelul creat la problema anterioară cu perspectiva de date, conform
cunoştinţelor voastre generale legate de acest domeniu.
Capitol 4: Perspectiva resurselor unui proces de afaceri
Un alt aspect, care trebuie luat în considerare atunci când se modelează procesele de
afaceri este perspectiva resurselor. Această perspectivă, numită, și perspectivă organizațională,
indică cine sau ce desfășoară o activitate din proces. ‚Resursă’ este un termen generic pentru a
ne referi la cineva sau ceva implicat în executare unei activități din proces. O resursă poate fi:
• Un participant la proces, adică o persoană fizică cum ar fi angajatul John Smith.
• Un sistem software, de exemplu, un server sau o aplicație software.
• Un echipament, cum ar fi o imprimantă sau o instalație de fabricare.
Există resurse active, adică resurse care pot autonom să execute o activitate, și resurse
pasive, adică resurse care sunt doar implicate în desfășurarea unei activități. De exemplu, un
fotocopiator este utilizat de un contabil pentru a face o copie unui document, dar contabilul este
cel care efectuează activitatea de copiere. Deci, fotocopiator este o resursă pasivă în timp ce
contabilul este o resursă activă. Un buldozer este un alt exemplu al unei resurse pasive, deoarece
șoferul desfășoară activitatea de demolare.
Perspectiva de resurse a unui proces este interesată de modelarea resurselor active, deci
vom folosi termenul "resursa" pentru a ne referi la o "resursă activă". Frecvent, într-un model de
proces nu ne referim în mod explicit la o singură resursă, cum ar fi de exemplu un angajat John
Smith, ci ne referim la un grup de resurse, de exemplu contabil, care conține indivizi care sunt
interschimbabili, în sensul că orice membru al grupului poate realiza o anumită activitate. Astfel
de grupuri sunt numite clase de resurse. Exemple sunt o organizație întreagă, o unitate
organizațională sau un rol/funcție îndeplinit/ă de angajați.
Exemplul 8: Procesul de onorare a comenzilor este efectuat de către organizația
vânzătoare, care include două departamente: departamentul de vânzări; și departamentul de
depozitare și distribuție. Comanda de achiziție este primită de departamentul de depozitare și
de distribuție, unde este și realizată verificarea stocului. Această operațiune este efectuată în
mod automat de către un sistem ERP care interoghează baza de date a depozitului. În cazul în
care produsul este în stoc, acesta este preluat din depozit înainte ca departamentul de vânzări
să confirme comanda. După care, departamentul de vânzări emite o factură și așteptată
încasarea. În același timp, produsul este livrat de departamentul de depozitare și distribuție.
Procesul se termină prin arhivarea comenzii în departamentul de vânzări. În cazul în care
produsul nu este în stoc, sistemul ERP al departamentului de depozitare și distribuție verifică
disponibilitatea materiilor prime prin accesarea catalogului de furnizori. Odată ce materiile prime
au fost obținute, departamentul de depozitare și distribuție realizează fabricarea produsului.
Procesul se termină cu confirmarea comenzii de achiziție și arhivarea acesteia de către
departamentul de vânzări.
BPMN conține două elemente pentru modelarea resurselor: ‚pools’ (piscine) și ‚swimlanes’ (benzi
de înot). Pool-urile sunt în general folosite pentru a modela clase de resurse, swimlane-urile sunt
utilizate pentru a împărți un pool în sub-clase sau resurse unice. Nu există restricții cu privire la
resursele specifice pe care un pool sau un swimlane ar trebui să le modeleze. Se folosește, de
obicei, un pool pentru a modela o afacere parte ca o organizație întreagă (cum ar fi vânzătorul în
exemplul nostru), și un swimlane pentru a modela un departament, unitate, echipa sau sistem
software/echipament în cadrul acestei organizații. În exemplul nostru, am împărți pool-ul firmei
vânzătoare în două swimlane-uri: una pentru departamentul de depozitare si distribuție, cealaltă
pentru departamentul de vânzări.
Swimlane-urile pot fi imbricate una în alta în mai multe niveluri. De exemplu, dacă e
nevoie să modelăm atât un departament cât și rolurile în acest departament, putem folosi un
swimlane exterior pentru departament, și un swimlane interior pentru fiecare rol din cadrul
respectivului departament. În exemplul de mai sus, am inclus în swimlane-ul Warehouse &
Distribution un alt swimlane pentru a reprezenta Sistemul ERP din acest departament.
Pool-urile și swimlane-urile sunt descrise ca dreptunghiuri în care putem plasa activități,
evenimente, gateway-uri, precum și obiecte de date. De obicei, se modelează aceste
dreptunghiuri orizontal, deși modelarea lor pe verticală este de asemenea posibilă. Numele pool-
ului/ swimlane-ului este afișat vertical în partea stângă a unui dreptunghi orizontal (sau orizontal
în cazul în care piscina / banda este verticală), pentru pool-uri, și pentru swimlane-uri care conțin
swimlane-uri imbricate, numele este închis într-o formație. Figura 14 prezinta exemplul de
onorare a unei comenzi de achiziție în care este modelată și perspectiva de resurse.
Fig. 14 – Modelul procesului de onorare a unei comenzi care include secvenţa activităţilor si perspectiva resurselor
Este important ca fiecare activitate să fie plasată în interiorul swimlane-ului corect. De
exemplu, am plasat Activitatea "Verifică disponibilitate stoc", în swimlane-ul Sistem-ului ERP din
Departamentul Warehouse & Distribution pentru a indica faptul că această activitate se
realizează automat de acest sistem. De asemenea, este important să se plaseze evenimentele în
mod corespunzător în cadrul swimlane-urilor. În exemplul nostru am plasat evenimentul "Ordin
cumpărare primit" în swimlane-ul sistemului ERP pentru a indică faptul că procesul începe în
sistemul ERP din Departamentul Warehouse & Distribution. De asemenea. am plasat
evenimentul "Comandă finalziată" în pool-ul Departamentului de vânzări pentru a indica faptul
că procesul de finalizează în acest departament. Nu are importanță în ce swimlane sunt plasate
obiectele de date, deoarece ele depind de activitățile de care sunt și nu au un executor. În cazul
gateway-urilor, trebuie să plasăm (X)OR-split-urile în același swimlane ca și activitatea de decizie
imediat precedentă. Pe de altă parte, un gateway AND–split poate fi plasat în orice swimlane,
deoarece aceste elemente sunt pasive (în sensul că ele se comportă în funcție de contextul lor).
Se pot organiza swimlane-uri într-un pool sub forma unei matrice în cazul în care avem
nevoie să modelăm structuri organizaționale complexe. De exemplu, dacă avem o organizație în
care rolurile cuprind diferite departamente, am putea folosi swimlane-uri orizontale pentru a le
modela. Dar, am putea folosi și swimlane-uri verticale pentru a modela rolurile în cadrul acestor
departamente. Țineți minte, totuși, că în BPMN fiecare activitate poate fi efectuată de către o
singură resursă. Astfel, în cazul în care o activitate se află în intersecția unui swimlane orizontal
cu un swimlane vertical, ea va fi efectuată prin resursa care îndeplinește caracteristicile ambelor
swimlane-uri, de exemplu, o resursă care are rolul respectiv dar și aparține acelui departament.
Deseori, există mai mult părți implicate într-un proces de afaceri. De exemplu, în procesul
de onorare a comenzilor, există patru părți: vânzătorul, clientul și cei doi furnizori ai vânzătorului.
Fiecare parte poate fi modelată printr-un pool. În exemplul nostru, putem folosi, astfel, un pool
pentru client, unul pentru vânzător și unul pentru fiecare furnizor. Fiecare dintre aceste pool-uri
va conține activități, evenimente, gateway-uri, precum și obiectele de date care modelează
respectiva organizație. Sau altfel spus, fiecare pool va modela același proces de afaceri din
punctul de vedere al unei anumite organizații. De exemplu, evenimentul "Ordin cumpărare
primit", care se află în pool-ul Vânzătorului, va avea o activitate corespunzătoare "Trimite ordin
de cumpărare", care se află în pool-ul Clientului. În mod similar, activitatea de "Experiază produs"
din pool-ul Vânzătorului vor avea în contrapartidă activitatea "Primește produs" în pool-ul
clientului. Deci, cum putem modela interacțiunile dintre pool-urile a două organizații care
colaborează? Nu putem folosi un flux de secvență pentru a conecta activități care aparțin
diferitelor pool-uri deoarece secvența flux nu poate trece granița unui pool. Pentru aceasta,
avem nevoie să utilizăm un element specific numit flux de mesaje.
Un flux de mesaje reprezintă fluxul de informații între două clase de resurse separate
(pool-uri). Acesta este descris ca o linie întreruptă, care începe cu un cerc gol și se termină cu un
vârf de săgeată gol, și poartă o etichetă care indică conținutul mesajului (de exemplu un fax, o
comandă de cumpărare, dar, de asemenea, o scrisoare sau un apel telefonic). Adică, fluxul de
mesaje modelează curgerea oricărui tip de comunicare între cele două organizații, nu contează
dacă acest lucru este electronic (cum ar fi trimiterea unui ordin de cumpărare prin e-mail sau
transmiterea unui fax), sau manual (efectuarea unui apel telefonic sau predarea unei scrisori pe
hârtie).
Figura 15 prezinta modelul complet pentru onorarea unei comenzi de cumpărare, inclusiv
pool-uri pentru client și cei doi furnizori. Aici putem vedea că fluxurile mesaj sunt etichetate
informațiile pe care le transmit (de exemplu, "Materii prime" sau "Expediere adresa". Un flux de
mesaje de intrare poate conduce la crearea unui obiect de date de către activitatea care primește
mesajul. De exemplu, mesajul "Materii prime" este primit de activitate "Obținerea de materii
prime de la Furnizor 1", care apoi creează obiectul de date "Materii prime". Acesta este și cazul
comenzii de cumpărare, care este generat de evenimentul de start "Comandă de cumpărare
primită" din conținutul fluxului de mesaje primite. Nu e nevoie să creați un obiect de date pentru
fiecare flux de mesaje recepționat, numai atunci când informațiile vehiculate prin mesaj sunt
necesare în altă parte în proces. În cazul nostru, obiectul de date "materii prime", este consumat
de activitate "Fabricare produse". În mod similar, nu avem nevoie să reprezentăm în mod explicit
obiectul de date folosit într-un mesaj de ieșire, dacă acest obiect de date nu este necesar în altă
parte în proces. De exemplu, activitatea "Emite factură" generează o factură care este trimisă
clientului, dar nu este modelat nici un obiect de date "factură", deoarece acesta nu este
consumat de către o altă activitate în pool-ul Vânzătorului.
O diagramă BPMN care dispune de două sau mai multe pool-uri poate fi numită și
diagramă de colaborare. Figura 15 arată diferite utilizări ale unui pool într-o diagramă de
colaborare. Un pool (cum ar fi cel al Vânzătorului) se numește proces privat, sau ‚white box pool’,
din moment ce arată cum organizația vânzătorului participă efectiv la procesul de onorare a
comenzilor în ceea ce privește activitățile, evenimentele, gateway-urile, precum și obiectele de
date. Dimpotrivă, un pool cum este cel al clientului sau cele ale celor doi furnizori se numește
proces public, sau ‚black box pool’, deoarece ascunde modul în care aceste organizații participă
efectiv în onorarea comenzilor. Pentru a economisi spațiu, putem reprezenta un proces public
printr-un dreptunghi gol care poartă numele la mijloc.
Întrebare: Black-box (proces public) sau White-box (proces privat)?
Modelarea unui pool ca un proces public sau unul privat este o chestiune de relevanță.
Când se modelează o diagramă de colaborare, o organizație poate decide dacă își expune sau nu
comportamentul ei intern, în funcție de cerințele proiectului. De exemplu, dacă modelăm
procesului de onorare a comenzilor din perspectiva vânzătorului, ar putea fi relevant să expunem
procesul de afaceri doar al vânzătorului, dar nu și cel al clientului și furnizorilor. Adică,
comportamentul intern al clientului și cel al furnizorilor nu sunt relevante pentru înțelegerea
modul în care vânzătorul ar trebui să onoreze comenzile de cumpărare, și, ca atare, acestea pot
fi ascunse. Pe de altă parte, în cazul în care avem nevoie să îmbunătățim modul în care vânzătorul
își onorează comenzile de cumpărare, ne-ar putea interesa, de asemenea, ce trebuie să facă un
furnizor să livreze materii prime, pentru că o întârziere în furnizarea de materii prime va încetini
fabricarea produselor în organizația vânzătorului. În acest caz, ar trebui să reprezentăm, de
asemenea, furnizorii, folosind procese private.
Tipul de pool afectează modul în care folosim fluxul de mesaje pentru a ne conecta la
pool. Un mesaj poate trece granița unui pool ‚white box’ și se poate conecta direct la o activitate
sau un eveniment în cadrul acestui pool. De exemplu, mesajul prin care se transmite comanda
de cumpărare se termină la evenimentul de start în pool-ul Vânzător. Pe de altă parte, deoarece
un pool black-box este gol, fluxurile de mesaje trebuie să se oprească la graniță sau să pornească
de la aceasta. Țineți cont de faptul că un flux de mesaje este utilizat doar pentru a conecta două
pool-uri și nu pentru a conecta două activități în același pool (în acest caz folosim o săgeată care
indică secvența).
O activitate care este sursa unui mesaj, cum ar fi "Emite factură" din pool-ul Vânzător se
numește o activitate de trimitere. Mesajul este trimis la finalizarea execuției activității. Pe de altă
parte, o activitate care primește un mesaj - cum ar fi "Preia adresa de livrare" este activitate
receptor. Execuția unei astfel de activități nu va fi începe până când mesajul de intrare nu a fost
primit. O activitate poate atât să primească dar și să trimită mesaje, atunci când aceasta are atât
un flux de mesaje de intrare cât și unul de ieșire (de exemplu, "Plătește factura"). Executarea
acestei activități va începe atunci când atât tokenul aferent fluxului de control cât și mesajul de
intrare este receptat. La finalizarea activității, un token va fi trimis de-a lungul arcului de ieșire
dar și mesajul va fi trimis. În cele din urmă, atunci când un flux de mesaje este receptat de un
eveniment de start (ca și "Comandă de cumpărare primită") acest eveniment va fi marcat cu un
plic deschis (vezi Fig. 15). Acest tip de eveniment este numit eveniment mesaj. Un eveniment
mesaj poate fi legat la un obiect de date, modelându-se astfel stocarea conținutului mesajului de
intrare.
Fig. 15 – Modelul procesului de onorare a unei comenzi care include şi colaborarea (mesajele) între vânzător, cumpărător şi doi furnizori
În exemplul de onorare a comenzilor am folosit pool-uri pentru a reprezenta părțile
implicate într-un proces de afaceri și swimlane-uri pentru a reprezenta departamentele și
sistemele în cadrul organizației vânzătorului. Am ales acest mode de modelare pentru că am vrut
să ne concentrăm asupra interacțiunilor dintre vânzător, client și cei doi furnizori. Așa cum am
menționat mai înainte, astfel se utilizează în mod tipic pool-urile și swimlane-urile. Cu toate
acestea, din moment ce BPMN nu prescrie ce tipuri de resurse ar trebui să fie asociate cu pool-
urile și swimlane-urile, am putea folosi aceste elemente diferit. De exemplu, în cazul în care se
pune accent pe interacțiunile dintre departamente ale unei organizații, putem modela fiecare
departament ca un pool, și putem folosi swimlane-urile pentru a detalia resursele din cadrul
fiecărui departament (de exemplu, în unități sau roluri). În orice caz, ar trebui să evităm să folosim
pool-urile și swimlane-urile pentru a modela participanții cu numele lor (deoarece persoanele
tind să se schimbe frecvent în cadrul unei organizații), și mai degrabă ar trebui să folosim rolul
participantului (de exemplu, funcționar financiar). Pe de altă parte, putem folosi pool-urile și
swimlane-urile pentru a reprezenta software-ul specific, sisteme sau echipamente (de exemplu,
un sistem ERP), deoarece acestea schimba mai rar într-o organizație.
Exerciţii recapitulative:
4.6. Extindeţi modelul de proces aferent evaluării unei cereri de acordare a unui credit prin
adăugarea perspectivei resurselor pe baza următoarei descrieri:
„Procesul de evaluare a cererilor de credit este executat de patru roluri din cadrul unei bănci: un
funcționar financiar verifică istoricul de credit al solicitantului, un evaluator de proprietăți este
responsabil pentru evaluarea garanțiilor imobiliare, un funcționar de la departamentul asigurări
trimite solicitantului oferta de asigurare în cazul în care acest lucru este necesar. Toate celelalte
activități sunt efectuate de către consultantul de credite, care este principalul punct de contact
cu solicitantul.”
4.7. Extindeţi modelul de proces de la exerciţiul precedent prin modelarea interacţiunii
(schimbului de mesaje) între bancă şi client.
Bibliografie curs
1. Dumas, M., La Rosa, M., Mendling, J., Reijers, H.A., Fundamentals of Business Process
Management, Springer, Berlin, 2013
2. Grosskopf, A., Decker, G., Weske, M., The process: business process modeling using
BPMN, Meghan Kiffer Press, 2009
3. Havey, M., Essential business process modeling, O'Reilly Media, Incorporated, 2005
4. Weske, M., Business Process Management: Concepts, Languages, Architectures, Springer,
Berlin, 2012
5. Wohed, P., van der Aalst, W.M.P., Dumas, M. and terHofstede, A.H.M., Pattern-based
Analysis of BPMN-An extensive evaluation of the Control-flow, the Data and the Resource
Perspectives, BPM Center Report BPM-05-26, 2005
6. *** Lucrări științifice jBoss, http://www.jboss.org/research/papers/
7. *** Documentație online Optaplanner,
https://docs.optaplanner.org/7.6.0.Final/optaplannerdocs/html_single/index.html#whatIsOpta
Planner
8. *** Documentație online jBPM, https://docs.jboss.org/jbpm/release/7.6.0.Final/jbpm-
docs/html_single/
9. *** Documentație online Drools,
https://docs.jboss.org/drools/release/7.6.0.Final/drools-docs/html_single/index.html
10. *** Documentație online Șabloane ale fluxurilor de lucru,
http://www.workflowpatterns.com/
Recapitulare
La sfârșitul acestui curs, ar trebui să fiţi în măsură să citiţi, să înțelegeţi și să puteţi construi
un model de proces de afaceri folosind elementele de modelare de bază ale BPMN. Elementele
de bază ale unui model de proces BPMN includ: activități simple, evenimente, gateway-uri,
obiecte de date, pool-uri, și swimlane-uri. Activitățile modelează lucrul din cadrul unui proces.
Evenimente definesc începutul și sfârșitul unui proces, și semnalizează dacă ceva ce se întâmplă
în timpul executării sale. Gateway-urile modelează: decizii exclusive sau inclusive urmate de
unirea ramurilor, paralelism urmat de sincronizare, respectiv repetiție.
S-a mai explicat diferența între un model de proces și o instanță a procesului. Un model de proces
descrie toate modurile posibile, prin care un proces de afaceri poate fi executat. Pe de altă parte,
o instanță de proces denotă o execuție specifică a unui proces din toate modurile de execuţie
posibile. Progresul execuţiei, sau starea, unei instanțe de proces este reprezentată de distribuţia
token-urilor în model. Folosind token-uri putem defini comportamentul gateway-urilor.
Aţi mai învățat cum să folosiţi obiectele de date pentru a modela fluxul de informații între
activități și evenimente. Un obiect de date capturează un artefact fizic sau electronic: necesar
pentru a executa o activitate sau a declanșa un eveniment; sau care rezultă din execuția unei
activităţi sau din declanşarea unui eveniment. Obiecte de date pot fi stocate într-un depozit de
date (cum ar fi o bază de date sau dulap fizic) astfel încât să poată fi stocate în afara procesului
în care acestea sunt/au fost create.
De asemenea, aţi văzut că pool-urile și swimlane-urile pot fi folosite pentru a modela atât
resursele umane cât și cele non-umane, care desfășoară activități din proces. Pool-urile sunt clase
de resurse, în general, în timp ce swimlane-urile sunt folosite pentru a împărţi pool-urile în sub-
componente. Interacțiunea dintre pool-uri este modelată prin fluxuri de mesaje. Fluxurile de
mesaje pot fi conectate direct de marginile unui pool, dacă detaliile interacțiunii între
transmiţător şi receptor nu sunt relevante.
Activitățile, evenimentele, gateway-urile, artefactele, și resursele aparțin celor 3
perspective principale de modelare ale unui proces de afaceri. Punctul de vedere funcțional
surprinde activitățile care sunt efectuate într-un proces de afaceri, în timp ce perspectiva control-
flow combina aceste activități și evenimentele conexe stabilind necesitatea desfăşurării acestora
într-o anumită ordine. Perspectiva de date acoperă artefactele create şi manipulate în timpul
execuţiei procesului. Perspectiva de resurse acoperă resursele (umane şi non-umane) care
efectuează diverse activități.
Exerciţii Recapitulative
ER1: Ce fel de tipuri de split-uri şi join-uri pot fi modelate într-un model de proces? Creaţi un
model, bazat pe un exemplu din lumea reală, pentru fiecare din ele.
ER2: Creaţi o descriere textuală a următorului model:
ER8: Extindeţi modelul din exercițiul ER6 prin adăugarea perspectivei de date.
ER9: Extindeţi modelul din exerciţiul ER8 prin adăugarea perspectivei resurselor. Există resurse
nonumane?
ER10: Modelaţi următorul proces, din toate cele 3 perspective:
Într-un tribunal, în fiecare dimineață actele aferente cauzelor care nu au fost judecate în ziua
precedentă sunt verificate pentru a se asigura că ele sunt în ordine pentru ședința de judecată
din acea zi. În cazul în care unele documente lipsesc, se iniţiază o căutare. În caz contrar,
documentele sunt duse fizic în sala de judecată. După ce toate documentele sunt gata, acestea
sunt predate către grefier. Între timp ordinea de zi a judecătorului este distribuită persoanelor
implicate în procesele judecate. Ulterior, audierile se desfășoară.
ER11: Modelaţi următorul proces, din toate cele 3 perspective:
Procesul de revendicare a daunelor auto începe atunci când un client depune o cerere cu
documentația relevantă. Departamentul de Relaţii cu Publicul de la asiguratorul auto verifică
documentele pentru conformitatea completării și înregistrează cererea. Următor,
Departamentul de Evaluare a Daunelor preia cererea și verifică asigurarea. Apoi, se face o
evaluare a daunelor fizice. Dacă evaluarea are un rezultat pozitiv, un garaj este sunat pentru
autorizarea reparațiilor și plata este programata (în această ordine). În caz contrar, cererea este
fost respinsă. În orice caz (dacă rezultatul este pozitiv sau negativ), un mesaj este trimis către
client și procesul este considerat încheiat.
ER11: Modelaţi următorul proces, din toate cele 3 perspective:
Atunci când o cerere este primită, un inspector verifică în primul rând dacă solicitantul este
asigurat. Dacă nu, solicitantul este informat că cererea trebuie să fie respinsă prin trimiterea unei
notificări automate prin-un sistem SAP. În caz contrar, un inspector superior evaluează gradul de
severitate al cererii. Bazat pe rezultatul evaluării se clasifică cererile în simple sau complexe, iar
formularele corespunzătoare sunt trimise solicitantului, din nou folosind sistemul SAP. Odată ce
formularele sunt returnate, ele sunt verificate de către inspector. În cazul în care formularele
conţin toate detaliile relevante, cererea este înregistrată în sistemul de management al cererilor
de despăgubire și procesul se termină. În caz contrar, solicitantul este informat că trebuie să
actualizeze formularele prin intermediul sistemului SAP. După primirea formularelor actualizate,
ele sunt verificate din nou, de către inspector pentru a vedea dacă toate detaliile au fost
furnizate, și așa mai departe.