Albero ricoprente minimo

Un grafo planare insieme al suo albero ricoprente minimo

Nella teoria dei grafi, dato un grafo con archi pesati, l'albero ricoprente minimo o albero di copertura di costo minimo (minimum spanning tree, MST)[1] è un albero ricoprente nel quale sommando i pesi degli archi si ottiene un valore minimo.

Definizione formale

Dato un grafo G = ( N , A ) {\displaystyle G=(N,A)} non orientato, connesso e pesato e assumendo che w ( u , v ) R + {\displaystyle w(u,v)\in \mathbb {R} ^{+}} sia una funzione peso per G {\displaystyle G} .

Un MST per G {\displaystyle G} è un insieme di archi tale che:[2]

w ( M S T ) = min M S T S ( u , v ) M S T w ( u , v ) . {\displaystyle w(MST)=\min _{MST\in S}\sum _{(u,v)\in MST}w(u,v).}

Dove S {\displaystyle S} è l'insieme di tutti gli alberi ricoprenti T {\displaystyle T} di G {\displaystyle G} , ovvero l'insieme di tutti i suoi sottografi che rispettano le seguenti condizioni:

  • T A {\displaystyle T\subseteq A} , quindi T {\displaystyle T} contiene solo una parte degli archi originali, al limite tutti, ma non di più.
  • ( N , T ) {\displaystyle (N,T)} è connesso: i nodi sono tutti collegati tra loro.

Modello matematico

Dato un grafo G = ( N , A ) {\displaystyle G=(N,A)} non orientato e connesso con costi c i , j {\displaystyle c_{i,j}} associati agli archi e vettore dei flussi sugli archi

x i , j = { 1 , se l'albero contiene l'arco  ( i , j ) , 0 , altrimenti . {\displaystyle x_{i,j}={\begin{cases}1,&{\text{se l'albero contiene l'arco }}(i,j),\\0,&{\text{altrimenti}}.\end{cases}}}

Un albero di copertura di costo minimo (MST) è la soluzione del seguente modello matematico[3]

min ( i , j ) A c i j x i j , ( i , j ) A x i j = n 1 (vincolo grafo connesso) , i S , j S x i j | S | 1 , S A , | S | 3 (vincolo assenza di cicli nel grafo) , {\displaystyle {\begin{aligned}&\min \sum _{(i,j)\in A}c_{ij}x_{ij},\\&\sum _{(i,j)\in A}x_{ij}=n-1\quad {\text{(vincolo grafo connesso)}},\\&\sum _{i\in S,j\in S}x_{ij}\leqslant |S|-1,\qquad \forall S\subseteq A,|S|\geqslant 3\quad {\text{(vincolo assenza di cicli nel grafo)}},\end{aligned}}}

dove S {\displaystyle S} è l'insieme degli archi che compongono l'albero di copertura T {\displaystyle T} e ha le seguenti proprietà:

  • è un sottoinsieme di A {\displaystyle A} (insieme degli archi del grafo);
  • la cardinalità di tale insieme deve essere almeno uguale a 3 (dato che con meno di 3 elementi in un insieme non si può creare un ciclo).

Il vincolo sull'assenza di cicli nel grafo può essere anche espresso utilizzando il concetto di taglio in un grafo. Il secondo vincolo del modello quindi diventerà:

i S , j S x i j + i S , j S x i j 1 , S N (vincolo nodi connessi) . {\displaystyle \sum _{i\in S,j\notin S}x_{ij}+\sum _{i\notin S,j\in S}x_{ij}\geqslant 1,\qquad \forall S\subseteq N\quad {\text{(vincolo nodi connessi)}}.}

Condizioni di ottimalità

L'albero di copertura di costo minimo T {\displaystyle T} che si ottiene applicando un algoritmo risolutivo è ottimo se rispetta le seguenti condizioni:

  • sui cicli: T {\displaystyle T} è un albero di copertura di costo minimo ( u , v ) T c u , v c i , j ,   ( i , j ) {\displaystyle \quad \Leftrightarrow \quad \forall (u,v)\notin T\quad c_{u,v}\geq c_{i,j},\ \forall (i,j)} in un cammino da u {\displaystyle u} a v {\displaystyle v} in T {\displaystyle T} ;
  • sui tagli: T {\displaystyle T} è un albero di copertura di costo minimo ( u , v ) T c u , v c i , j ,   ( i , j ) {\displaystyle \quad \Leftrightarrow \quad \forall (u,v)\in T\quad c_{u,v}\leq c_{i,j},\ \forall (i,j)} in un taglio formato eliminando l'arco ( u , v ) {\displaystyle (u,v)} da T {\displaystyle T} .

Algoritmi per il calcolo di un MST

Algoritmo generico

L'algoritmo generico per la costruzione di un albero ricoprente minimo è di tipo greedy.[1] Dato un grafo G = ( V , E ) {\displaystyle G=(V,E)} non orientato, connesso e con una funzione peso w : E R + {\displaystyle w\colon E\rightarrow \mathbb {R} ^{+}} , l'algoritmo agisce su un insieme A T {\displaystyle A\subseteq T} (con T {\displaystyle T} MST di G {\displaystyle G} ) al quale ad ogni passo viene aggiunto un arco ( u , w ) {\displaystyle (u,w)} che permette ad A {\displaystyle A} di restare un sottoinsieme del MST finale, un tale arco verrà chiamato safe-edge.[2]

  1. A {\displaystyle A\leftarrow \varnothing }
  2. while A T {\displaystyle A\neq T} do
    1. ( u , v ) {\displaystyle (u,v)\leftarrow } safe-edge ( A ) {\displaystyle (A)}
    2. A A ( u , v ) {\displaystyle A\leftarrow A\cup (u,v)}
  3. end while
  4. return A

Trovare l'arco corretto

Per trovare l'arco corretto è necessario ricorrere ad alcune definizioni.

Per prima cosa ( S , V S ) {\displaystyle (S,V-S)} con S V {\displaystyle S\subseteq V} verrà chiamato taglio, e avremo che:

  1. un arco ( u , v ) {\displaystyle (u,v)} attraversa un taglio ( S , V S ) {\displaystyle (S,V-S)} se e solo se u S v ( V S ) {\displaystyle u\in S\land v\in (V-S)} .
  2. un albero A E {\displaystyle A\subseteq E} rispetta un taglio ( S , V S ) {\displaystyle (S,V-S)} se e solo se ( u , v ) A {\displaystyle \not \exists (u,v)\in A} che attraversa il taglio.

Un arco ( u , v ) {\displaystyle (u,v)} viene definito leggero rispetto ad un taglio ( S , V S ) {\displaystyle (S,V-S)} , se è di peso minimo tra tutti gli archi che attraversano quel taglio.

Dato un insieme A {\displaystyle A} di archi contenuto in qualche albero di connessione minima, sia ( S , V S ) {\displaystyle (S,V-S)} un taglio che rispetta A {\displaystyle A} e sia a = ( u , v ) {\displaystyle a=(u,v)} un arco leggero, allora l’arco a {\displaystyle a} è sicuro (safe-edge).

Algoritmi usati nella pratica

Dato un grafo esistono diversi algoritmi per individuare un suo MST, tra questi:

Foresta ricoprente minima

Nel caso in cui il grafo non sia connesso, cioè sia il risultato dell'unione di più grafi connessi, si può ancora definire una foresta ricoprente minima come l'unione degli alberi ricoprenti individuati sui singoli grafi connessi. In grafi connessi, foresta ed albero ricoprente coincidono.

Applicazioni

Gli spanning tree minimi hanno applicazioni dirette nella progettazione di reti, tra cui reti di computer, reti di telecomunicazioni, reti di trasporto, reti di approvvigionamento idrico e rete elettrica.[4]

Altre applicazioni pratiche basate sugli Alberi Ricoprenti Minimi:

  • Tassonomia.[5]
  • Clustering: clustering dei punti nel piano,[6]
  • Costruzione degli alberi per il broadcasting nelle reti di computer.[7]
  • Feature extraction curvilinea in computer vision.[8]
  • Riconoscimento della scrittura per espressioni matematiche.[9]
  • Regionalizzazione di aree socio-geografiche, ovvero raggruppare delle aree in regioni omogenee e contigue.[10]
  • Gli Alberi ricoprenti minimi possono essere utilizzati per descrivere i mercati finanziari.[11][12] Una matrice di correlazione può essere creata calcolando un coefficiente di correlazione tra due stocks qualunque. Questa matrice può essere rappresentata topologicamente come una rete complessa ed un albero minimo ricoprente può essere costruito per visualizzarne le relazioni.

Note

  1. ^ a b Goodrich-Tamassia, p. 564.
  2. ^ a b (EN) Samuel J. Lomonaco , Jr., Minimal-Spanning-Trees (PDF), su csee.umbc.edu, Università del Maryland - Dipartimento di ingegneria informatica ed elettrica. URL consultato il 2 gennaio 2017.
  3. ^ G. Bigi, A. Frangioni, G. Gallo, S. Pallottino, M. G. Scutellà, Appunti di Ricerca Operativa, SEU - Servizio Editoriale Universitario di Pisa
  4. ^ R. L. Graham e Pavol Hell, On the history of the minimum spanning tree problem, in Annals of the History of Computing, vol. 7, n. 1, 1985, pp. 43–57, DOI:10.1109/MAHC.1985.10011, MR 783327.
  5. ^ P. H. A. Sneath, The Application of Computers to Taxonomy, in Journal of General Microbiology, vol. 17, n. 1, 1º agosto 1957, pp. 201–226, DOI:10.1099/00221287-17-1-201, PMID 13475686.
  6. ^ T. Asano, B. Bhattacharya, M. Keil e F. Yao, Clustering algorithms based on minimum and maximum spanning trees, Fourth Annual Symposium on Computational Geometry (SCG '88), vol. 1, 1988, pp. 252–257, DOI:10.1145/73393.73419.
  7. ^ Yogen K. Dalal e Robert M. Metcalfe, Reverse path forwarding of broadcast packets, in Communications of the ACM, vol. 21, n. 12, 1º dicembre 1978, pp. 1040–1048, DOI:10.1145/359657.359665.
  8. ^ Minsoo Suk e Ohyoung Song, Curvilinear feature extraction using minimum spanning trees, in Computer Vision, Graphics, and Image Processing, vol. 26, n. 3, 1º giugno 1984, pp. 400–411, DOI:10.1016/0734-189X(84)90221-4.
  9. ^ Ernesto Tapia e Raúl Rojas, Recognition of On-line Handwritten Mathematical Expressions Using a Minimum Spanning Tree Construction and Symbol Dominance (PDF), in Graphics Recognition. Recent Advances and Perspectives, Lecture Notes in Computer Science, vol. 3088, Berlin Heidelberg, Springer-Verlag, 2004, pp. 329–340, ISBN 978-3-540-22478-5.
  10. ^ R. M. AssunÇão, M. C. Neves, G. Câmara e C. Da Costa Freitas, Efficient regionalization techniques for socio‐economic geographical units using minimum spanning trees, in International Journal of Geographical Information Science, vol. 20, n. 7, 2006, pp. 797–811, DOI:10.1080/13658810600665111.
  11. ^ Mantegna, R. N. (1999). Hierarchical structure in financial markets. The European Physical Journal B-Condensed Matter and Complex Systems, 11(1), 193-197.
  12. ^ Djauhari, M., & Gan, S. (2015). Optimality problem of network topology in stocks market analysis. Physica A: Statistical Mechanics and Its Applications, 419, 108-114.

Bibliografia

  • Michael T. Goodrich, Roberto Tamassia, Strutture dati e algoritmi in Java, Bologna, Zanichelli Editore, 2007, pp. 562-565, ISBN 978-88-08-07037-1.

Altri progetti

Altri progetti

  • Wikibooks
  • Wikimedia Commons
  • Collabora a Wikibooks Wikibooks contiene testi o manuali sull'albero ricoprente minimo
  • Collabora a Wikimedia Commons Wikimedia Commons contiene immagini o altri file sull'albero ricoprente minimo

Collegamenti esterni

  Portale Informatica
  Portale Matematica