Algoritmo de Dinic

El algoritmo de Dinic es un algoritmo de Tiempo polinómico para la computación de un Flujo maximal en una red de flujo, concebida en 1970 por el científico de la computación Yefim Dinitz, israelí de origen soviético.[1]​ El algoritmo es ejecutado en un tiempo de y está basado en el Algoritmo de Edmonds-Karp, el cual a su vez se ejecuta en un tiempo , y utiliza trayectorias de aumento más cortas. La introducción de los conceptos nivel de grafo y bloqueo de flujo es lo que define el rendimiento del algoritmo de Dinic.

Definición

editar

Se tiene el grafo   que será una red de flujo con   es la capacidad y   el flujo del arco  .

La capacidad residual es un mapeo   definido como,
  1. Si  ,
     
     
  2.   de otra manera.
El grafo residual es el grafo  , donde
 .
La trayectoria de aumento es una ruta   en el grafo residual  .
Se define   como la longitud del camino más corto desde   hasta   en  .Entonces el nivel del grafo de   es el grafo  , donde
 .
El bloqueo del flujo es un   flujo   de manera tal que el grafo   con   no tiene ninguna ruta  .

Algoritmo

editar

Algoritmo de Dinic

Entrada: Una red  .
Salida: Un flujo   de valor   maximizado.
  1. Se tiene   para cada  .
  2. Construir  desde   de  . Si  , detener y retornar el resultado  .
  3. Encontrar un bloqueo de flujo   en  .
  4. Aumentar el flujo   by   y volver al paso 2.

Análisis

editar

Se puede demostrar que el número de arcos en cada bloqueo de flujo, es incrementado en al menos 1 unidad cada vez, y por lo tanto hay al menos   bloqueos de flujo en el algoritmo, donde   es el número de vértices en la red. El nivel del grafo   puede ser construido por búsqueda en anchura en un tiempo de   y un bloqueo de flujo en cada nivel del grafo puede ser encontrado en un tiempo de  . Por lo tanto, el tiempo del algoritmo de Dinic es de  .

Usando una estructura de datos llamada árboles dinámicos, el tiempo de ejecución para encontrar un bloqueo de flujo en cada fase puede ser reducido a   y por lo tanto el tiempo de ejecución del algoritmo de Dinic puede ser reducido a  .

Casos Especiales

editar

En redes con capacidades de unidad, el tiempo de ejecución es mucho mayor. Cada bloqueo de flujo puede ser encontrado en un tiempo de  , y es demostrable que el número de fases no excedan   y  . En estos casos el algoritmo se ejecuta en un tiempo de  .

En las redes surgidas durante la solución del problema de apareamiento, el número de fases está limitado por  ,lo cual resulta en un limitado tiempo de  . El algoritmo resultante a raíz de esto es conocido como algoritmo Hopcroft–Karp. De manera más general, este límite se mantiene para cualquier red unitaria — un tipo de red en la que cada vértice, excepto para los vértices fuente y sumidero, o bien tienen un único arco de capacidad, o un único arco con salida, y todas las demás capacidades son valores enteros arbitrarios.[2]

Ejemplo

editar

Esta es una simulación del algoritmo de Dinic. En el nivel del grafo  , los vértices marcados en rojo son los valores  . Las rutas en azul forman el bloqueo de flujo.

     
1.      

El bloqueo de flujo está constituido por

  1.   con 4 unidades de flujo,
  2.   con 6 unidades de flujo, and
  3.   con 4 unidades de flujo.

Por lo tanto el bloqueo del flujo es de 14 unidades y el valor del flujo   es 14. Note que cada ruta de aumento en el flujo de bloqueo tiene 3 arcos.

2.      

El bloqueo de flujo está constituido por

  1.   con 5 unidades de flujo.

Por lo tanto el bloqueo del flujo es de 5 unidades y el valor del flujo   es 14 + 5 = 19. Note que cada ruta de aumento en el flujo de bloqueo tiene 4 arcos.

3.      

Desde   no puede ser alcanzado en  . El algoritmo termina y retorna un valor m'aximo de flujo de 19. Note que en cada bloqueo de flujo, el n'umero de arcos en la ruta de aumento se incrementa en al menos 1 valor.

Historia

editar

El algoritmo de Dinic fue publicado en 1970 por el ex ruso científico de la computación Yefim (Chaim) A. Dinitz , quien hoy es miembro del departamento de Ciencias de la Computación en Universidad Ben-Gurión del Néguev (Israel). Dicha publicación se realizó antes que la del algoritmo de Edmonds-Karp, el cual fue publicado en 1972, pero fue descubierta antes. Ambos demostraron cada uno por su cuenta, que en el algoritmo de Ford-Fulkerson, si cada ruta de aumento es la más corta, el largo de la ruta de aumento es no decreciente.

Véase también

editar

Referencias

editar
  1. Yefim Dinitz (1970). «Algorithm for solution of a problem of maximum flow in a network with power estimation». Doklady Akademii nauk SSSR 11: 1277-1280. Archivado desde el original el 22 de agosto de 2016. Consultado el 22 de abril de 2012. 
  2. Tarjan, 1983, p. 102.