Informatica industriala

23
Informatica industriala Sisteme distribuite de control

description

Informatica industriala. Transformata fourier discreta (DFT) si Transformata Fourier rapida (FFT). Transformate Fourier. Obiectiv: descompunerea unui semnal complex intr-o suma de semnale simple semnale simple: set de semnale sinusoidale pentru ca sunt ortogonale - PowerPoint PPT Presentation

Transcript of Informatica industriala

Page 1: Informatica industriala

Informatica industriala

Sisteme distribuite de control

Page 2: Informatica industriala

Solutii distribuite in aplicatii de control In viziune clasica:

sistem de control = sistem centralizat argumente:

cooordonare si control unitar determinism si predictibilitate lant ierarhizat al responsabilitatilor

Intr-o viziune mai noua: sistem de control = sistem complex, cu multe functionalitati

indeplinite in regim autonom, prea complexe pentru o solutie “monolit”

argumente: natura distribuita a procesului controlat si implicit a elementelor

de automatizare fiabilitate sporita si toleranta la defecte (prin solutii redondante) posibilitati de comunicare si control de la distanta, inclusiv prin

internet

Page 3: Informatica industriala

Caracteristicile unui sistem distribuit de control Tipuri de distributie:

distributia echipamentelor distributia datelor distributia controlului (a programelor)

Sistem distribuit v.s. Sistem paralel (multiprocesor) sistem paralel = corelatie stransa intre componente atat la nivel fizic

cat si la nivel logic fizic: magistrala, memorie, resurse comune pentru procesoare; timp de

comunicatie neglijabil logic: solutioneaza in paralel o anumita problema

sistem distribuit = corelare stransa la nivel logic dar relaxata la nivel fizic fizic: conexiune prin retea (timp de comunicatie comparabil cu timpul de

procesare a datelor) logic: sistemul rezolva a problema comuna (legatura stransa intre componentele

logice ale aplicatiei) Sisteme distribuite v.s. Retele de calculatoare

la retele lipseste obiectivul/celul comun la sisteme distribuite: un obiectiv comun (ex: controlul unei fabrici)

Page 4: Informatica industriala

Functii specifice ale unui sistem distribuit de control Mecanism uniform, unitar şi transparent de acces la resursele sistemului

identificarea univoca (fara ambiguitati a elementelor sistemului) – prin identificator unic (ex: adresa MAC, IP, URL, URI, etc.)

accesul (logic) la resurse prin nume simbolice ex: “temperatura cuptor 1” in loc de adresa fizica not+adresa registru in

cadrul nodului asigura transferul transparent al unor functii de la un nod defect la unul

nou mai usor de inteles pentru operatorul uman

utilizarea unor standarde/protocoale de comunicatie specifice pentru anumite dispozitive:

nivelul 8 (utilizator) la retelele industriale, cu “profile” definite pentru fiecare categorie de echipamente (ex: motoare, senzori, etc.)

accesul trebuie sa mascheze redondanta datelor sau intarzierile si erorile de comunicatie

reconfigurarea automata a sistemului in cazul inlocuirii unor componente defecte

a se vedea mecanismul de inlocuire a nodurilor la protocolul ASi Solutie posibila: implementarea conceptului de “Dispozitiv virtual de

control” modalitate uniforma de acces la resurse indiferent de natura

acestora sau de pozitia lor in sistem

Page 5: Informatica industriala

Functii specifice ale unui sistem distribuit de control Mecanisme de sincronizare

necesar pentru cooperarea intre componentele sistemului: controlul accesului la resurse partajate imprimarea unor dependenţe între taskuri (inclusiv de ordonare

intre taskuri) armonizarea unor actiuni concurente

mecanisme clasice de sincronizare: clasice: cutii poştale, indicatoare de condiţie, zone critice,

monitor, etc referinta la un ceas de timp global: prin sincronizarea ceasurilor

locale necesar pentru ordonarea evenimentelor stabilirea relatiilor de cauzalitate intre evenimente (care a fost

cauza si care a fost efectul) stabilirea ordinii de accesare a unor resurse partajate (ex: FCFS –

primul sosit primul servit)

Page 6: Informatica industriala

Functii specifice ale unui sistem distribuit de control Mecanisme de replicare

necesar pentru: cresterea fiabilitatii prin replicarea componentelor critice cresterea vitezei de acces la date prin replicarea acestora in

mai multe puncte Administrarea evenimentelor

sistemele de control sunt prin excelenta sisteme “reactive” care raspund la diverse evenimente (ex: avertizari, avarii, etc.)

administrarea globala a evenimentelor este mult mai complexa in cazul sistemelor distribuite (fenomenul de relativitate, datorat vitezei limitate de transmisie a mesajelor)

solutie posibila: server de evenimente modelarea conceptului de eveniment:

atribute: nume, conditia de generare, conditia de stergere, lista taskurilor care trebuie atentionate, lista taskurilor care trebuie activate, etc.

Page 7: Informatica industriala

Functii specifice ale unui sistem distribuit de control Achiziţia periodică a unor parametri de proces si

generarea de comenzi majoritatea functiilor de control au un caracter ciclic trebuie sa se respecte perioada de achizitie si de

generare, altfel erori de calcul Reprezentare grafica a sistemului

vizualizarea parametrilor de proces: numeric si grafic vizualizarea schemei logice a procesului posibilitatea de a transmite comenzi specifice de catre

operatorul uman vizualizarea evolutiei in timp a unor parametri de

proces si a evenimentelor

Page 8: Informatica industriala

Structurarea datelor de proces moduri de structurare:

pe baza poziţiei fizice ocupate în sistem (ex.: aparţin de un anumit dispozitiv sau echipament),

pe baza unor criterii de funcţionalitate (ex.: parametrii unei bucle de reglaj să constituie o structură unică),

pe bază de importanţă sau priorităţi pe baza nivelului ierarhic de control de care aparţin (ex.:

nivelul buclei de reglaj, nivelul coordonării procesului sau nivelul administrativ)

tipuri de date din punct de vedere a persistentei datelor: date privind starea curenta a procesului (imaginea de

moment a procesului): au o valabilitate limitata in timp se va specifica momentele in care se face achizitia si durata de

valabilitate a datelor date privind evolutia procesului: “date logate”

Page 9: Informatica industriala

Implementarea unei aplicatii de control complexe Solutia monolitica

fiecare componenta are o functie bine definita si ocupa o anumita pozitie ierarhica

avantaje: asigura o vedere generala si unitara asupra sistemului dezavantaje:

fiabilitate redusa, defectarea unei componente duce la oprirea sistemului proiectare dificila: trebuie sa se tina cont de toate aspectele pe care le

implica sistemul Solutia distribuita:

aplicatia = set de componente autonome care indeplinesc diferite functionalitati ale sistemului;

avantaje: fiabilitate marita: oprirea/defectarea unei componente nu implica oprirea

celorlalte componente; pot fi construite simplu scheme redondante si tolerante la defecte

scalabilitate: pot fi adaugate noi componente fara modificarea componentelor existente

dezavantaje: aplicatia trebuie descompusa in componente autonome care lucreaza in

regim concurent/paralel

Page 10: Informatica industriala

Model conceptual al unui sistem distribuit de control bazat pe servicii Specificatii:

tipurile de servicii necesare într-un sistem de control modul de interacţiune a serviciilor facilităţile oferite de fiecare serviciu (interfaţa serviciului) modul de implementare a serviciilor

Principii constructive: gruparea funcţiilor de control în entităţi - astfel încât fiecare

entitate să poată să fie dezvoltată ca o aplicaţie autonomă; reducerea fluxului de informaţii între entităţi - cu scopul de a

reduce timpul consumat pentru schimbul de date şi pentru a simplifica interfaţa dintre entităţi

reducerea traficului în reţea - prin structurarea şi amplasarea corespunzătoare a datele

replicarea datelor - pentru creşterea eficienţei şi reducerea timpului de reacţie

reducerea numărului de nivele ierarhice, pentru a minimiza timpul de reacţie al sistemului

Page 11: Informatica industriala

Model conceptual al unui sistem distribuit de control bazat pe servicii Principii constructive:

evitarea implementării unor funcţii de control echivalente în mai mult de o entitate – pentru evitarea inconsistenţei şi a situaţiilor ambigue

fiecare serviciu (entitate de control) va include mecanisme de identificare a componentelor distribuite ale serviciului respectiv şi de reconfigurare dinamică a serviciului

se va asigura un mecanism special (simplificat) de acces la dispozitivele cu resurse limitate

fiecare serviciu va asigura un nivel de fiabilitate, impus de natura funcţiilor implementate

serviciile trebuie să includă mecanisme explicite de administrare a informaţiilor de timp

se va utiliza un mecanism unitar de acces la diferitele tipuri de servicii

Page 12: Informatica industriala

Modelul arhitectural al unui serviciu distribuit de control

Aplicaţie

Serviciul x

Alte servicii

Interfaţa de reţea

Nod de reţea

........

....

Noduri cu resurse limitate

Aplicaţie

Serviciul x

Alte servicii

Interfaţa de reţea

Nod de reţea

Aplicaţie

Serviciul x

Alte servicii

Interfaţa de reţea

Nod de reţea

Interfaţa de reţea

Executiv

Aplicaţie

Interfaţa de reţea

Executiv

Aplicaţie

Interfaţa de reţea

Executiv

Aplicaţie

Page 13: Informatica industriala

Modelul arhitectural al unui serviciu distribuit de control Principii de functionare:

Un serviciu este suma serviciilor locale de acelaşi tip implementate la nivelul fiecărui nod de reţea.

Un serviciu local interacţionează cu celelalte servicii în vederea îndeplinirii funcţiilor specifice de control.

O aplicaţie de control dezvoltată deasupra serviciilor de control interacţionează direct cu serviciul local în vederea obţinerii funcţiei dorite.

Dacă aplicaţia solicită accesul la o resursă dintr-un alt nod al reţelei atunci solicitarea este rezolvată de serviciul local, prin dialog cu serviciul echivalent din nodul unde se află resursa.

Din considerente de eficienţă şi timp de execuţie, în anumite cazuri aplicaţia poate să ia legătura direct cu serviciul local al nodului vizat.

Anumite dispozitive a căror resurse computaţionale nu permit implementarea locală a tuturor serviciilor, vor fi integrate în sistem prin intermediul unor noduri de administrare (noduri “proxi”).

Această soluţie este adecvată în multe aplicaţii de control, unde un dispozitiv de complexitate medie (ex.: regulator, controlor logic programabil) poate să gestioneze un set de elemente mai simple de automatizare (senzori şi elemente de execuţie).

Între nodul proxi şi nodurile simple va exista un protocol de comunicaţie simplificat, mai uşor de implementat într-un microsistem minimal. Nodul proxi va gestiona toate resursele nodurilor simple care i-au fost ataşate.

Page 14: Informatica industriala

Modelul arhitectural al unui serviciu distribuit de control Definirea serviciilor de control:

serviciul de timp serviciul de replicare serviciul de gestiune a resurselor serviciul de gestiune a evenimentelor serviciul de planificare a taskurilor serviciul de configurare şi alocare a sarcinilor set de componente grafice pentru interfaţa

utilizator

Page 15: Informatica industriala

Modelul arhitectural al unui serviciu distribuit de control

Serviciul de timp Serviciul de replicare

Gestiunea evenimentelor

Gestiunea resurselor

Serviciul de planificare

Interfaţa de reţea (nivelele 1-4)

Componente grafice Serviciul de configurare

Aplicaţia de control

Structura ierarhică a serviciilor de control la nivelul unui nod de reţea

Page 16: Informatica industriala

Serviciul de timp functia principala – asigurarea unei referinte unice de timp pentru intregul sistem necesara pentru:

sincronizarea componentelor lansarea unor taskuri periodice stabilirea relatiilor de cauzalitate intre evenimente

mecanisme de sincronizare a ceasurilor locale: solutie centralizata - algoritmul lui Christian

server central de timp care răspunde aplicaţiilor client care solicită o referinţă de timp

se tine cont de timpul mediu de transmisie a mesajului de sincronizare; se calculeaza si precizia de sincronizare

solutie distribuita – se genereaza o referinta de timp ca o medie a ceasurilor locale

periodic se genereaza cereri de resincronizare mai fiabil decat varianta centralizata

la aplicatiile de control: ajustarea ceasului local se va face treptat (in cuante de ajustare adaptate preciziei de calcul a agoritmului de reglaj) si niciodata nu se va da ceasul inapoi; altfel erorile de calcul pot genera comenzi gresite (ex: la regulator cu factor derivativ)

Page 17: Informatica industriala

Serviciul de replicare functia principala: evidenta resurselor replicate si asigurarea consistentei

acestora necesitatea:

pentru a asigura toleranta la defecte prin multiplicarea elementelor critice

pentru a inbunatati timpul de acces la anumite resurse ce se replica:

resurse fizice: senzori, elemente de calcul, elemente de stocare servicii de control: serviciu de gestiune a evenimentelor, serviciu de

acces la date, etc. serviciul este responsabil pentru:

identificarea dispozitivelor conectate în sistem identificarea resurselor de care dispune fiecare dispozitiv al

sistemului configurarea şi alocarea sarcinilor detecţia defectelor şi mascarea acestora prin reconfigurarea

sistemului

Page 18: Informatica industriala

Serviciul de gestiune a resurselor functia de baza: de a asigura un acces uniform, unitar şi transparent la resursele

distribuite ale sistemului serviciul este responsabil pentru:

determinarea componentelor sistemului şi a configuraţiei acestora (dispozitive fizice, componente program, etc.)

determinarea parametrilor de proces disponibili achiziţia şi stocarea periodică a valorilor parametrilor de proces transmisia periodică de comenzi către elementele de execuţie citirea şi scrierea aleatoare a unor parametri, la solicitarea expresă a aplicaţiei de

control marcarea datelor achiziţionate cu o referinţă de timp şi verificarea perisabilităţii

datelor menţinerea unei baze de date cu imaginea curentă a procesului controlat înregistrarea evoluţiei unor parametrii de proces, specificaţi de aplicaţia de control

Model conceptual bazat pe ideea de “Dispozitiv virtual de control” promovat de standardul MMS (Manufacturing Message Specification) dispozitiv virtual de control = obiect care grupează un set de resurse, organizate

sub forma mai multor liste. Fiecare listă grupează resurse de un anumit tip (ex: variabile de proces, proceduri,

evenimente). un dispozitiv virtual modelează un dispozitiv real şi grupează resursele acestuia. există posibilitatea grupării unor resurse în raport de funcţionalitatea pe care o

îndeplinesc în sistem.

Page 19: Informatica industriala

Serviciul de gestiune a evenimentelor

functii de baza: detectarea evenimentelor notificarea unor componente privind aparitia unor evenimente inregistrarea evenimentelor lansarea de taskuri ca reactie la un anumit eveniment

serviciul va gestiona numai evenimentele care au fost definite in prealabil !!! definirea unui eveniment:

o expresie logică alcătuită din variabile de proces şi constante, care, dacă este adevărată determină apariţia unui eveniment

un anumit comportament privind marcarea apariţiei, păstrarea şi ştergerea evenimentului

o listă de taskuri care trebuie notificate la apariţia evenimentului o listă de taskuri care trebuie activate în urma apariţiei unui evenimen

detectia evenimentelor: pe baza de intreruperi si rutine de tratare a intreruperilor modul special de verificare periodica a conditiilor de activare prin receptia unui mesaj care indica un anumit eveniment

Page 20: Informatica industriala

Serviciul de planificare a taskurilor

functia de baza: lansarea în execuţie a taskurilor unei aplicatii, cu respectarea restrictiilor de diferite tipuri (de timp, de sincronizare, de ordonare, etc.)

strategii de planificare (a se vedea cursul anterior):

fara prioritati: FCFS, RR cu prioritati:

in functie de importanta in functie de restrictiile de timp: RM, EDF, SLF

Page 21: Informatica industriala

Serviciul de configurare şi alocare a sarcinilor

functia de baza: configurarea sistemului de control in regim dinamic rolul: adaptarea unei configuratii generice la particularitatile unui proces

tehnologic ce se configureaza:

numarul si tipul dispozitivelor conectate in sistem functia fiecarei componente parametrii asociati dispozitivelor fizice limite admisibile si limite de avertizare/avarie scheme de inlocuire automata a dispozitivelor defecte tipurile de evenimente acceptate in sistem frecventa de achizitie a datelor

alocarea sarcinilor tine cont de: disponibilitatea componentelor de a indeplini o anumita functie gradul de incarcare a dispozitivelor restrictiile de timp impuse

Page 22: Informatica industriala

Set de componente grafice pentru interfaţa utilizator

functii de baza: vizualizarea grafica a datelor transmiterea de comenzi ale operatorului uman

Tipuri de elemente grafice: obiect grafic simplu – obiect care nu se conectează la o variabilă de proces, are doar rolul

de a sugera imaginea reală a unei componente de proces (ex.: cabluri de legătură, conducte, rezervoare, etc.)

variabilă digitală de intrare – obiect care reprezintă starea unui senzor bipoziţional variabilă digitală de ieşire – obiect care reprezintă starea unui element de execuţie

bipoziţional variabilă analogică de intrare – obiect care reprezintă un senzor analogic variabilă analogică de ieşire – obiect care reprezintă un element de execuţie controlat printr-

un semnal analogic grafic – obiect care reprezintă evoluţia în timp a unei variabile de proces

atributele unui obiect grafic: o listă de imagini – care simbolizează o componentă fizică de proces, în mai multe stări o referinţă către o variabilă de proces – a cărei valoare sau stare se vizualizează o valoare de afişare – care păstrează valoarea afişată o variabilă de stare – care indică dacă obiectul este vizibil sau nu o referinţă către o funcţie de vizualizare – care generează imaginea obiectului grafic o referinţă către o funcţie de conversie – care transformă valoarea variabilei de proces într-

o valoare de afişare o referinţă către o funcţie de modificare a valorii variabilei de proces alte atribute şi funcţii specifice pentru diferite tipuri de obiecte

Page 23: Informatica industriala

Ce se urmareste prin modelul distribuit propus?

fiabilitate ridicată – prin caracterul distribuit al serviciilor scalabilitate – prin posibilitatea adăugării de noi servicii pe lângă

cele existente, fără modificarea celor existente reconfigurabilitate dinamică – prin identificarea automată şi

periodică a configuraţiei de sistem şi realocarea dinamică a sarcinilor în cazul unor defecţiuni

toleranţă la defecte – prin existenţa unor componente redondante şi prin reconfigurarea automată a sistemului în caz de defect

timp de reacţie mai scurt – prin distribuirea “inteligenţei” şi a responsabilităţii decizionale

transparenţa comunicaţiei în reţea – prin funcţii de acces la resursele distribuite oferite de serverul local