+ All Categories
Home > Documents > TEHNICI DE COMPRESIE A IMAGINILOR - …alpha.imag.pub.ro/site_old/release/archive/08.pdf · Sursa...

TEHNICI DE COMPRESIE A IMAGINILOR - …alpha.imag.pub.ro/site_old/release/archive/08.pdf · Sursa...

Date post: 17-Feb-2018
Category:
Upload: buidung
View: 218 times
Download: 0 times
Share this document with a friend
12
1 LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR C. VERTAN TEHNICI DE COMPRESIE A IMAGINILOR LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR C. VERTAN Compresie = reducerea cantitatii de date necesare pentru reprezentarea unei imagini Compresia trebuie sa fie reversibila (functie inversabila). Compresie fara pierderi (eficienta sursei de informatie, Th. 1 Shannon) cu pierderi Compresie in domeniul valorilor (cuantizare, reducere numar de culori) instante ale algoritmilor de clustering in domeniul spatial si al valorilor LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR C. VERTAN Cerinte contradictorii : Raport de compresie :: Calitatea imaginii reconstruite LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR C. VERTAN Compresie fara pierderi = codarea surselor de informatie pentru canale fara perturbatii In aceasta categorie intra metode generale (indiferente de semnificatia valorilor) sau metode dedicate continutului de tip imagine (se bazeaza pe corelatia valorilor vecine). Metode generale : codare entropica (Huffman) codare aritmetica codare Ziv-Lempel Metode specifice: RLE (Run Length Encoding) WBS (White Block Skipping)
Transcript
Page 1: TEHNICI DE COMPRESIE A IMAGINILOR - …alpha.imag.pub.ro/site_old/release/archive/08.pdf · Sursa de informatie emite 6 simboluri, cu probabilitatile Huffman S = [ s1; s2; ... Tip

1

LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR

C. VERTAN

TEHNICI DE COMPRESIE AIMAGINILOR

LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR

C. VERTAN

Compresie = reducerea cantitatii de date necesare pentru reprezentareaunei imagini

Compresia trebuie sa fie reversibila (functie inversabila).

Compresiefara pierderi (eficienta sursei de informatie, Th. 1 Shannon)cu pierderi

Compresiein domeniul valorilor (cuantizare, reducere numar de culori)

instante ale algoritmilor de clustering

in domeniul spatial si al valorilor

LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR

C. VERTAN

Cerinte contradictorii :

Raport de compresie :: Calitatea imaginii reconstruite

LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR

C. VERTAN

Compresie fara pierderi = codarea surselor de informatie pentrucanale fara perturbatii

In aceasta categorie intra metode generale (indiferente desemnificatia valorilor) sau metode dedicate continutului de tipimagine (se bazeaza pe corelatia valorilor vecine).

Metode generale :codare entropica (Huffman)codare aritmeticacodare Ziv-Lempel

Metode specifice:RLE (Run Length Encoding)WBS (White Block Skipping)

Page 2: TEHNICI DE COMPRESIE A IMAGINILOR - …alpha.imag.pub.ro/site_old/release/archive/08.pdf · Sursa de informatie emite 6 simboluri, cu probabilitatile Huffman S = [ s1; s2; ... Tip

2

LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR

C. VERTAN

CodareaHuffman

Este o codare cu lungime variabila a cuvantului de cod si dictionarde cuvinte de cod (dictionarul - sau Look-Up Table - arata caresunt cuvintele de cod ce corespund unui anumit mesaj al sursei).

Codarea inseamna construirea dictionarului de codare.

Sursa deinformatie Simbol

emissi

Dictionar de codare

si 01101

Simb. Cuvinte cod

transmisiestocare …

01101

LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR

C. VERTAN

CodareaHuffmanPrincipiul de codare :

cuvintele de cod de lungime mica (scurte) se aloca simbolurilormai probabile

cuvintele de cod de lungime mare (lungi) se aloca simbolurilormai putin probabile

Algoritm :

construirea de surse de informatie restranse prin reunirea simbolurilorcele mai putin probabile ale sursei anterioare.

LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR

C. VERTAN

CodareaHuffmanSursa de informatie emite 6 simboluri, cu probabilitatile

S = [ s1 ; s2 ; s3 ; s4 ; s5 ; s6]P = [0.25 ; 0.3 ; 0.2 ; 0.1 ; 0.1 ; 0.05].

s2 0.3

s1 0.25

s3 0.2

s4 0.1

s5 0.1

s6 0.05

Ordoneaza simbolurile surseiin ordine descrescatoare aprobabilitatilor.

Ultimele doua simboluri (cele maiputin probabile) sunt reunite intr-unsingur simbol, formand osursa restransa.

LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR

C. VERTAN

CodareaHuffman

s2 0.3

s1 0.25

s3 0.2

s4 0.1

s5 0.1

s6 0.05

s2 0.3

s1 0.25

s3 0.2r1 0.15s4 0.1

Continua procedeulde restrangere panala obtinerea unei surse restranse cu2 simboluri.

Page 3: TEHNICI DE COMPRESIE A IMAGINILOR - …alpha.imag.pub.ro/site_old/release/archive/08.pdf · Sursa de informatie emite 6 simboluri, cu probabilitatile Huffman S = [ s1; s2; ... Tip

3

LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR

C. VERTAN

CodareaHuffman

s2 0.3

s1 0.25

s3 0.2

s4 0.1

s5 0.1

s6 0.05

s2 0.3

s1 0.25

s3 0.2r1 0.15s4 0.1

s2 0.3

s1 0.25r2 0.25s3 0.2

LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR

C. VERTAN

CodareaHuffman

s2 0.3

s1 0.25

s3 0.2

s4 0.1

s5 0.1

s6 0.05

s2 0.3

s1 0.25

s3 0.2r1 0.15s4 0.1

s2 0.3

s1 0.25r2 0.25s3 0.2

r3 0.45s2 0.3

s1 0.25

LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR

C. VERTAN

CodareaHuffman

s2 0.3

s1 0.25

s3 0.2

s4 0.1

s5 0.1

s6 0.05

s2 0.3

s1 0.25

s3 0.2r1 0.15s4 0.1

s2 0.3

s1 0.25r2 0.25s3 0.2

r3 0.45s2 0.3

s1 0.25

r4 0.55r3 0.45

LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR

C. VERTAN

CodareaHuffman

r4 0.55r3 0.45

Incepand de la ultimasursa restransa se alocacate un bit de 0 si 1 celordoua simboluri.

01r3 0.45

s2 0.3

s1 0.25 Codurile simbolurilor reunite sunt prefixpentru codurilor simbolurilor ce le compun.

Se repeta alocarea de biti pana cand s-aucodat toate simbolurile sursei initiale.

00

01

Page 4: TEHNICI DE COMPRESIE A IMAGINILOR - …alpha.imag.pub.ro/site_old/release/archive/08.pdf · Sursa de informatie emite 6 simboluri, cu probabilitatile Huffman S = [ s1; s2; ... Tip

4

LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR

C. VERTAN

CodareaHuffman

r3 0.45s2 0.3

s1 0.25

100

01

s2 0.3

s1 0.25r2 0.25s3 0.2

1011

s2 0.3

s1 0.25

s3 0.2r1 0.15s4 0.1

100101

s2 0.3

s1 0.25

s3 0.2

s4 0.1

s5 0.1

s6 0.05

1000

1001

LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR

C. VERTAN

CodareaHuffman

Tabel de codare

s2 0.3 00 2

s1 0.25 01 2

s3 0.2 11 2

s4 0.1 101 3

s5 0.1 1000 4

s6 0.05 1001 4

Simb. Prob. Cuvant cod Lung. codLung. medie acuvintelor de cod :

2 * 0.3 +

2 * 0.25 +

2 * 0.2 +

3 * 0.1 +

4 * 0.1 +

4 * 0.05 = 2.4 biti

LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR

C. VERTAN

CodareaHuffman

Tabelul de codare trebuie transmis impreuna cu sirul decuvinte de cod (sau tabelul de codare trebuie pre-stabilit).

Codarea este eficienta pentru sursa (deci setul de probabilitati) pentrucare s-a generat tabelul de codare.

Codarea nu se poate face on-line (sunt necesare toate simbolurileemise de sursa pentru a putea calcula probabilitatile acestora).

Codarea Huffman este folosita in [aproape] toate standardele decodare a imaginilor.

LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR

C. VERTAN

Codare Ziv-Lempel

dictionarul de codare sa nu trebuiasca transmis (dictionarul seva genera la receptie)

codarea sa fie on-line (pe masura parcurgerii datelor)

Page 5: TEHNICI DE COMPRESIE A IMAGINILOR - …alpha.imag.pub.ro/site_old/release/archive/08.pdf · Sursa de informatie emite 6 simboluri, cu probabilitatile Huffman S = [ s1; s2; ... Tip

5

LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR

C. VERTAN

CodareaRLE

Pentru un sir binar se codeaza numarul simbolurilor succesivede acelasi fel.

Ex. : sirul 0 0 0 1 1 1 1 0 0 1 0 1 0 0 0 se va coda ca :

0 3 4 2 1 1 1 3

Valoareaprimului

simbol dinsir

Lungimile blocurilor de simbolurisuccesive de acelasi fel.

Run Length Encoding

LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR

C. VERTAN

CodareaRLETransmisia fax:

RLE + codare Huffman a lungimilor (runs)

Tabele de codare Huffman sunt standardizate (sunt deci pre-stabilite)si transmisia lor nu este necesara.

Limitare a lungimii maxim codate la ......

LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR

C. VERTAN

CodareaWBSWhite Block Skipping

Sirul binar de codat este impartit in grupuri (blocuri) de cate B biti.

Un bloc alb (toti bitii ce il compun de valoare 0) este codat cu un unicbit de 0.

Un bloc ne-alb (nu are toti bitii 0) este prefixat cu un bit de 1 si copiat.

Ex. : sirul 0 0 0 1 1 1 1 0 0 1 0 1 0 0 0 se va coda cu B=3 ca :

0 1 1 1 1 1 1 0 0 1 1 0 1 0

LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR

C. VERTAN

CodareaWBSCand este codarea eficienta ?

Fie un sir ce are n0 blocuri albe dintr-un total de n blocuri.Fiecare bloc alb este inlocuit cu 1 bitFiecare bloc ne-alb este inlocuit de B+1 biti

Lungime initiala sir : nBLungime sir comprimat : n0 + (n-n0)(B+1)

Compresie : n0 + (n-n0)(B+1) < nB

n < n0B

n0 / n > 1/B

Page 6: TEHNICI DE COMPRESIE A IMAGINILOR - …alpha.imag.pub.ro/site_old/release/archive/08.pdf · Sursa de informatie emite 6 simboluri, cu probabilitatile Huffman S = [ s1; s2; ... Tip

6

LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR

C. VERTAN

TEHNICI DE COMPRESIE AIMAGINILOR (cont.)

LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR

C. VERTAN

Compresia cu arbori cuaternari (quadtrees)

Ideea de baza : divizarea regulata a suportului spatial al imaginii,daca acesta are valori uniforme, si asocierea de noduridintr-un arbore.

LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR

C. VERTAN

QuadtreeProbleme :

cand se construiesc descendenti ai unui nod ?cum se stabileste legatura dintre pozitia nodurilor si cea a

regiunilor corespunzatoare ?

Nodurile devin ne-terminale (cu descendenti) daca zonele dinimagine care le corespund nu sunt suficient de uniforme (“suficient”se traduce prin respectarea unei conditii de uniformitate la nivelulregiunii corespunzatoare.

Deci : regiunile neuniforme sunt “taiate” in patru parti egale (sferturi).

Regula de alocare a descendentilor este indiferenta, atata vreme cateste aceeasi pentru constructia intregului arbore.

LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR

C. VERTAN

QuadtreeEx. reguli de alocare a descendentilor

1 2

34

1 2

43

1 2 3 4

1 2 3 4

sens orar

curba Z

Page 7: TEHNICI DE COMPRESIE A IMAGINILOR - …alpha.imag.pub.ro/site_old/release/archive/08.pdf · Sursa de informatie emite 6 simboluri, cu probabilitatile Huffman S = [ s1; s2; ... Tip

7

LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR

C. VERTAN

Quadtree:exemplu

LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR

C. VERTAN

Quadtree:exemplu

LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR

C. VERTAN

Quadtree:exemplu

LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR

C. VERTAN

QuadtreeAlgoritm :

1. Regiunea curenta = intreaga imagineaceasta este radacina arborelui.

2. Verifica uniformitatea regiunii curente:daca regiunea este uniforma, nodul din arbore este terminaldaca regiunea nu este uniforma, regiunea este taiata in patru

si nodul curent capata patru descendenti.

3. Fiecare noua regiune devien regiune curenta.

4. Repeta de la 2 pana cand :regiunile au o dimensiune minima prestabilita (la limita 1 pixel)regiunile sunt uniforme.

Page 8: TEHNICI DE COMPRESIE A IMAGINILOR - …alpha.imag.pub.ro/site_old/release/archive/08.pdf · Sursa de informatie emite 6 simboluri, cu probabilitatile Huffman S = [ s1; s2; ... Tip

8

LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR

C. VERTAN

QuadtreeAlgoritmul, in descrierea sa anterioara, este o varianta bazata pedescompunerea regiunilor (split); arborele se construieste incepand curadacina, si deci algoritmul este de tip

top - down.

Complexitatea este mare, pentru ca fiecare pixel va fi parcurs de unnumar de ori egal cu adancimea sa in arbore.

Varianta eficienta a algoritmului va necesita citirea o singura dataa fiecarui pixel si agregarea regiunilor uniforme; arborele seconstruieste incepand cu frunzele, si deci algoritmul devine

bottom - up.

LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR

C. VERTAN

Quadtreecolor

Etapa 1 : imaginea initiala este radacinaarborelui.

Imaginea nu este uniforma, deci sedescompune in sferturi si se construiescnodurile de pe nivelul 1 al arborelui.

LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR

C. VERTAN

Quadtreecolor

Numai sfertul 2 este suficient de uniform; nodul corespunzator devineterminal si primeste “culoarea medie” din regiune.Celelalte regiuni vor trebui descompuse.

LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR

C. VERTAN

Quadtreecolor

Page 9: TEHNICI DE COMPRESIE A IMAGINILOR - …alpha.imag.pub.ro/site_old/release/archive/08.pdf · Sursa de informatie emite 6 simboluri, cu probabilitatile Huffman S = [ s1; s2; ... Tip

9

LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR

C. VERTAN

Quadtreecolor

Compresia este data de cantitatea de informatie necesara pentru amemora pozitia in arbore a nodurilor terminale.

LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR

C. VERTAN

Reconstructia

Pozitia nodurilor terminale in arbore (adancime, cale de la radacina)stabileste reconstructia (ce dimensiune are blocul, unde se pune).

LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR

C. VERTAN

OriginalReconstructie

Erorile (si gradul de compresie) sunt determinate de pragul deuniformitate acceptata pentru regiuni.

LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR

C. VERTAN

TEHNICI DE COMPRESIE AIMAGINILOR (cont.)

Cuantizarea vectoriala (vector quantization)(VQ)

Page 10: TEHNICI DE COMPRESIE A IMAGINILOR - …alpha.imag.pub.ro/site_old/release/archive/08.pdf · Sursa de informatie emite 6 simboluri, cu probabilitatile Huffman S = [ s1; s2; ... Tip

10

LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR

C. VERTAN

Compresie = reducerea cantitatii de date necesare pentru reprezentareaunei imagini

Compresia trebuie sa fie reversibila (functie inversabila).

Compresiefara pierderi (eficienta sursei de informatie, Th. 1 Shannon)cu pierderi

Compresiein domeniul valorilor (cuantizare, reducere numar de culori)

instante ale algoritmilor de clusteringin domeniul spatial si al valorilor

LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR

C. VERTAN

Compresia prin cuantizare vectoriala (VQ)

Tip de compresie bazata pe “dictionar de cuvinte de cod” : portiunidin imagine (blocuri) sunt inlocuite cu pozitia la care se gasestein dictionar cuvantul de cod (blocul standard de codare) cel maisimilar.

Blocurile sunt de forma regulata si impart imaginea fara suprapuneri(dimensiuni tipice 4 x 4, 8 x 8, 16 x 16).

Compresia este cu atat mai puternica cu cat blocurile sunt dedimensiune mai mare.

Compresia este cu atat mai precisa cu cat dictionarul este mai mare.

LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR

C. VERTAN

VQProiectarea VQ dupa rata de compresie

Blocurile de cod din dictionar sunt de dimensiune m x nDictionarul are N blocuri de cod; indexul e reprezentat pe log2N bitiValoarea oricarui pixel este reprezentata pe P biti.

Fiecare grup de m x n pixeli din imagine (care este reprezentat initialpe m x n x P biti) este reprezentat dupa codare de indexul unui blocde cod, deci de log2N biti.

Compresia va fi data de :

! Raportul anterior presupune cunoasterea dictionarului; alfel,dictionarul trebuie transmis (memorat) si el impreuna cu codul imaginii.

NlogmnPC

2=

LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR

C. VERTAN

VQ

1

2

3

4

5

6

7

1 1 1 11 6 1 17 5 4 12 2 2 2

cod

dictionarimagineoriginala

imaginede-comprimata

Page 11: TEHNICI DE COMPRESIE A IMAGINILOR - …alpha.imag.pub.ro/site_old/release/archive/08.pdf · Sursa de informatie emite 6 simboluri, cu probabilitatile Huffman S = [ s1; s2; ... Tip

11

LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR

C. VERTAN

VQCalitatea compresiei este data de dictionarul folosit.

Ideea este de a sintetiza dictionarul pe un set suficient de marede imagini “tipice”, astfel ca blocurile de cod sa reprezinte binecaracteristicile imaginii.

Sinteza dictionarului este o instanta a unui algoritm de clustering : din blocurile-exemplu extrase din imaginile setului de antrenamentsa se extraga blocuri caracteristice (prototipuri).

Cazul cel mai defavorabil pentru compresia cu VQ : folosirea unuidictionar dedus pentru imagini cu caracteristici total diferite.

LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR

C. VERTAN

ClusteringPunerea problemei :

un set de N puncte, descrise de vectori de dimensiune ptrebuie impartit in C clase (grupuri, clustere).

)x,...,x,x(N,...,2,1i},{X

ip2i1ii

i

===

xx

Impartirea (partitionarea) setului de puncte in clase :indice de apartenenta a fiecarui punct (carei clase ii apartine)

Exprimarea cantitativa a conceptului de “partitionare buna”.criterii de calitate a partitiei.

LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR

C. VERTAN

ClusteringApartenenta punctelor la clase

C,...,2,1j,N,...,2,1i,uij ==

Apartenenta punctului xi la clasa j :

Modele de clustering :

Net (binar) :

���

∉∈

=ji

jiij Clasa,0

Clasa,1u

xx

Nuantat (fuzzy) :

]1,0[uij ∈C,...,2,1j,N,...,2,1i ==∀

LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR

C. VERTAN

ClusteringMasuri de calitate a claselor

clase compacte : centrul clasei este “aproape” de toate puncteleclasei (punctele clasei sunt bine aproximate decentrul clasei).

clasa are suficient de multe puncte

clase bine separate : distantele dintre centrele claselor sa fie catmai mari.

Cele doua cerinte sunt adeseori contradictorii.

Page 12: TEHNICI DE COMPRESIE A IMAGINILOR - …alpha.imag.pub.ro/site_old/release/archive/08.pdf · Sursa de informatie emite 6 simboluri, cu probabilitatile Huffman S = [ s1; s2; ... Tip

12

LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR

C. VERTAN

Clusteringnet

Basic ISODATA (k-means, C-means)

ISODATA = Iterative Self Organizing Data Analysis Technique

Se fixeaza numarul de clase dorit, C.

Calitatea partitiei (a claselor) e caracterizata de eroarea globala deaproximare a vectorilor de date prin prototipurile claselor.

� ��= ==

���

����

�−===

C

1j

N

1i

2jiij

C

1jjjij u),u(JJ µxµ ε

jµ prototipul (centroidul) clasei j

LABORATORUL DE ANALIZA ŞI PRELUCRAREA IMAGINILOR

C. VERTAN

Clusteringnet

Basic ISODATA (C-means)

=

=

=

=

=−=∂∂

N

1iij

N

1iiij

j

N

1ijiij

j

u

u

0)(u2J

µxµ

prototipurile claselor sunt mediile aritmeticeale vectorilor de date ce apartin claselor.

��

��� ≠∀−≤−=

rest ,0jk,,1u kiji

ijµxµx orice vector apartine

clasei de al careiprototip este cel maiapropiat.

Clusteringnet

Basic ISODATA (C-means)

1. alege un set aleator de prototipuri

2. calculeaza apartenenta fiecarui vector la una dintre claselepartitiei (vectorii apartin clasei de al carei prototip suntcei mai apropiati)

3. calculeaza prototipurile claselor ca media aritmetica a vectorilorapartind fiecarei clase

4. evalueaza criteriu de oprire :eroare globala suficient de mica ?numar de iteratii suficient de mare ?au fost vectori care sa isi schimbe apartenenta ?au fost prototipuri care s-au modificat semnificativ ?

5. repeta de la 2 daca e cazul.


Recommended