Ir al contenido

Algoritmo de Dinic

De Wikipedia, la enciclopedia libre

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.