Rete di flusso
Nella teoria dei grafi, una rete di flusso è un grafo orientato in cui ogni arco ha una capacità non negativa ed è attraversato da un flusso, ovvero un numero compreso fra 0 e la capacità dell'arco.
Le reti di flusso sono un'importante sezione della teoria dei grafi perché possono essere usate per modellare molte situazioni reali: si pensi ad esempio ad una rete stradale ed il relativo flusso di veicoli, o una rete idrica. Più in generale, ogni sistema che comprende il passaggio di qualcosa attraverso canali di capacità limitata e interconnessi fra loro, può essere rappresentato utilizzando una rete di flusso.
Definizione formale
modificaSi dice rete un grafo a cui è associata una funzione , detta funzione capacità. Senza perdita di generalità, assumiamo che se , allora anche , dal momento che se allora può essere aggiunto ad E e poi imporre .
Dati due nodi s e t di G distinti, detti rispettivamente sorgente e pozzo, allora è detta rete di flusso.[1]
Ad ogni nodo viene associato un coefficiente , che indica se genera o assorbe del flusso.[2] Nel primo caso il coefficiente sarà positivo e verrà chiamato domanda del nodo; nel secondo caso il coefficiente sarà negativo e verrà chiamato offerta del nodo. Se è nullo, è detto nodo di trasferimento.[2] Nel caso si dovesse modellare una rete di flusso con più sorgenti, è prassi comune creare una supersorgente, ovvero una nuova sorgente con archi di capacità infinita che la collegano a tutte le altre sorgenti. Così facendo le precedenti sorgenti diventano nodi "comuni", e ci si ritrova al caso con un'unica sorgente, senza variare il sistema poiché un flusso nella nuova rete corrisponde ad uno nell'originale. Un costrutto simile è utilizzato nel caso di più pozzi, con l'introduzione di un superpozzo.
Flussi
modificaEsistono vari tipi di funzione di flusso definibili in una rete di flusso. Le funzioni di flusso associano un numero a ciascuna coppia di nodi.
L'esempio basilare di una funzione di flusso è noto come pseudoflusso. Uno pseudoflusso è una funzione che soddisfa i due seguenti vincoli:[2]
- Vincolo sulla capacità. . Il flusso lungo un arco non può eccedere la capacità dello stesso.
- Emisimmetria. Il flusso lungo un arco deve essere di segno opposto se k viene attraversato da v a u. .
Partendo dalla definizione di pseudoflusso, si possono aggiungere ulteriori vincoli per ottenere tipi di flusso più specifici. Un flusso ammissibile[2] (denotabile semplicemente come "flusso") deve soddisfare la seguente regola:
- Conservazione del flusso. . Per ogni nodo il flusso entrante deve eguagliare quello uscente.[2]
Concetti utili per i problemi di flusso
modificaGrafo residuo
modificaDato un flusso ammissibile, il grafo residuo (relativo a ) è un grafo con gli stessi nodi del grafo mentre gli archi e le loro capacità dette residue, sono così definiti:
Cammino aumentante
modificaDato un flusso ammissibile, un cammino aumentante (rispetto a ) è un cammino orientato da a nel grafo residuo , dove è il nodo origine (o sorgente) e è il nodo destinazione (o pozzo).
Applicazioni
modificaLe reti di flusso hanno svariate applicazioni pratiche, poiché consentono di rappresentare con un modello matematico relativamente semplice situazioni reali. Il problema più frequentemente associato alle reti di flusso è quello del flusso massimo, ovvero trovare il valore massimo di flusso che può essere "generato" dalla sorgente ed arrivare al pozzo senza che si superino le capacità dei singoli archi. Il problema può essere risolto in maniera efficiente con l'algoritmo di Ford-Fulkerson. Un altro problema tipico di questo argomento è quello del flusso di costo minimo.
Note
modifica- ^ (EN) A.V. Goldberg, É. Tardos and R.E. Tarjan, Network flow algorithms, Tech. Report STAN-CS-89-1252, Stanford University CS Dept., 1989
- ^ a b c d e Domenico Cantone, Grafi e reti di flusso (PDF), su dmi.unict.it, Università di Catania, Dipartimento di Matematica e Informatica. URL consultato il 30 agosto 2016 (archiviato il 30 agosto 2016).
Bibliografia
modifica- Passacantando M. ; Pappalardo M. (2013). "Ricerca Operativa" Pisa University Press ISBN 9788867410736
Altri progetti
modifica- Wikimedia Commons contiene immagini o altri file su rete di flusso