Location via proxy:   [ UP ]  
[Report a bug]   [Manage cookies]                

Método de Ramificación y Acotación.

Descargar como docx, pdf o txt
Descargar como docx, pdf o txt
Está en la página 1de 16

Tecnológico Nacional de México

Instituto Tecnológico de la Chontalpa

Maestr
o:
Pablo Emmanuel
González Diaz.
Alumn
o:
Luis Alfonso Perera
Palma
Materia:
Investigación
Operacional. Tema:
Método de ramificación y
acotación.
Carrera:
Ing.
Industrial
Semestre:
4to
Fech
a:
29/06/202
1
Síntesis “Ramificación y acotación”

-Al igual que los métodos de búsqueda con retroceso:

se aplica a problemas de optimización con restricciones.


se genera el espacio de soluciones, organizándolo en un árbol (en general en un grafo).
no se genera el espacio de soluciones completo, sino que se podan bastantes estados.

Terminología:

-Nodo vivo: nodo del espacio de soluciones del que no se han generado aún todos sus hijos.

-Nodo muerto: nodo del que no se van a generar más hijos porque:

no hay más
no es completable, i.e., viola las restricciones
no producirá una solución mejor que la solución en curso

-Nodo en curso (o en expansión): nodo del que se están generando hijos

Diferencia fundamental con el método de búsqueda con retroceso:

-Búsqueda con retroceso:

Tan pronto como se genera un nuevo hijo del nodo en curso, este hijo pasa a ser el nodo en curso.

-Ramificación y acotación:

Se generan todos los hijos del nodo en curso antes de que cualquier otro nodo vivo pase a ser el nuevo
nodo en curso.

En consecuencia:

-Búsqueda con retroceso:

Los únicos nodos vivos son los que están en el camino de la raíz al nodo en curso.
-Ramificación y acotación:

Puede haber más nodos vivos. Se deben almacenar en una estructura de datos auxiliar: lista de nodos
vivos.

Diferentes estrategias de elegir el siguiente nodo de la lista de nodos vivos

Distintos órdenes de recorrido del árbol de soluciones

-FIFO: la lista de nodos vivos es una cola

» recorrido por niveles (en anchura)

-LIFO: la lista de nodos vivos es una pila

» recorrido en profundidad (D–búsqueda)

-Mínimo coste: la lista es una cola con prioridades

» recorrido “extraño”

La prioridad de un nodo se calcula de acuerdo con una función de estimación que mide cuánto de “prometedor”
es un nodo.

Primer punto clave de los métodos de ramificación y acotación: Encontrar un buen orden de recorrido (o
ramificación) de los nodos, es decir, definir una buena función de prioridad de los nodos vivos, para que las
soluciones buenas se encuentren rápidamente.

El esquema es el siguiente:

repetir

expandir el nodo vivo más prometedor; generar todos sus hijos; una vez generados, el padre se
mata;

para cada hijo hacer

sí tiene un coste esperado peor que el de la mejor solución en curso

entonces se mata sino


sí tiene un coste esperado mejor que el de la mejor solución en curso y no es solución

entonces se pasa a la lista de nodos vivos

sino {tiene un coste esperado mejor que el de la mejor solución en curso y es solución (el coste no es estimado
sino real)}

pasa a ser la mejor solución en curso y se revisa toda la lista de nodos vivos, eliminando los que prometen
algo peor de lo conseguido fsi, fsi,

f para hasta que la lista está vacía.

Problemas de optimización:

-Ahora la función o coste a minimizar ya no es la distancia de la raíz a la solución, sino una cierta función
objetivo dada

- ¿Qué ocurre si interesa buscar una solución de coste mínimo?

¿Encuentra el algoritmo esa solución? No.

Se expande la raíz, sus hijos se añaden a la cola de nodos vivos, se elige el hijo izquierdo, se expande y se
obtiene una solución de coste 20

(cuando la solución óptima tiene coste 10).


¿Por qué? Porque £x, y: c (x) < cˆ (y) ʌ c(x) > c(y)

– Teorema. Si para cada nodo x del árbol del espacio de estados es una estimación de c(x) tal que para todo
par de nodos y, z:

c ˆ (y) < c ˆ (z) - c(y) < c(z)

entonces el algoritmo mínimo coste termina y encuentra siempre una solución de mínimo coste.

-Problema: no es fácil encontrar una función de estimación con tales características y fácil de calcular.

-Conformarse con… Una función fácil de calcular y tal que para todo nodo x:

c ˆ (x) ≤ c(x)

y para cada solución:

c ˆ (x) = c(x)

En este caso, el algoritmo mínimo coste no siempre encuentra una solución de mínimo coste, pero puede
modificarse ligeramente…

Ramificación… y acotación:

-Problema de minimización de una función c(x) (función objetivo).

-Se utiliza una función de estimación que sea una cota inferior de todas las soluciones obtenidas desde x:

c ˆ (x) ≤ c(x)

-Suponer que se conoce una cota superior, U, del valor mínimo de c.

c(x*) = min x c(x) £ U


(i.e., cota pesimista de la solución del problema)
Regla de acotación:

x: c ˆ (x) > U, x puede ser podado y su solución descendiente de x: c(y) ³ c(x) ³ c ˆ (x) > U

-Si se actualiza el valor de U (al alcanzar una solución con un coste menor), todos los nodos vivos de coste
estimado mayor también se pueden podar (otra cosa es que no se haga por no disminuir la eficiencia)

-Valor inicial de U:

u utilizar alguna heurística (basada en información extra sobre el problema), o ∞

-Si el valor inicial de U es mayor o igual que el coste de una solución de mínimo coste, la regla de poda no
elimina ningún nodo ascendente de una solución de coste mínimo.

Construcción del algoritmo:

-Definición de la función de coste c(x) de forma que c(x) sea mínimo para todos los nodos que representen una
solución óptima.

- ¿Cómo?

si x es solución factible del problema de optimización: c(x) = función objetivo(x);


sí x no es factible: c(x) = ¥;
sí x representa una solución parcial (i.e. x puede ser completada a factible): c(x) = min{c(y) y es
descendiente de x}

¡Esta función es tan difícil de calcular como resolver el problema original!

-Se utiliza tal que para todo x.

-La función de estimación estima el valor de la función objetivo y no el coste computacional de alcanzar
una solución.
Puntos clave del método:

1. (Recordar) Encontrar un buen orden de recorrido o ramificación de los nodos, es decir, definir una buena
función de prioridad de los nodos vivos para que las soluciones buenas se encuentren rápidamente.

2. Encontrar una buena función de acotación o poda, U, para que se produzca el retroceso lo antes
posible.

Ejemplo:
Samuel Loyd : El juego del 15 o “ taken ”.
Problema publicado en un periódico de Nueva York
en 1878 y por cuya solución se ofrecieron 1000 dólares.

❖ El problema original:

1 2 3 4 1 2 3 4
?
5 6 7 8 5 6 7 8
9 10 11 12 9 10 11 12
13 15 14 13 14 15
Problema de Lloyd El objetivo

La solución de “fuerza bruta”:

-Buscar en el espacio de estados (es decir en todos los estados posibles alcanzados desde el
problema propuesto) hasta encontrar el objetivo.

¡Nótese que hay 16! ˜ 20’9x1012 posiciones, aunque sólo (?) la mitad pueden alcanzarse desde la
posición inicial propuesta por Lloyd …

¿Qué estados son alcanzables?


– Numeremos las casillas de 1 a 16.

– Dada una configuración o estado, sea Pos(i) la posición (entre 1 y 16) de la


ficha con el nº i, y sea Pos(16) la posición de la casilla vacía.

– Dado un estado, para cada ficha i, sea m(i) el número de fichas j tales
que j<i y Pos(j)>Pos(i).

m(i)=0, i=1,2,3,4,5,6,7 m (8) =m (9)=


1 2 3 4 m(10)=1 m(11)=0
m (12) =0 m(13)=m(14)=m(15)=1
8 5 m(16)=9
6
9 10 7 11
13 14 15 12
-Dado un estado, sea x=1 si la casilla vacía está en alguna de
las posiciones sombreadas y x=0 en caso contrario.

❖ Teorema. El estado objetivo es alcanzable desde un cierto estado si


para ese estado:
16
m(i) + x es par
i =1

Para el ejemplo anterior, dicha función vale 26, luego el


estado objetivo es alcanzable.
- Hijos de cada nodo = movimientos de la
casilla vacía (arriba, abajo, izquierda,
derecha)

- poda inicial: ningún nodo


tiene un hijo igual a su
padre.
algoritmo mínimoCoste (ent x0:nodo)
variables c:cola;{con prior. de <x,coste(x)>}
éxito:booleano; xcurso,x:nodo
principio
si esSol(x0) entonces escribir(x0)
sino
creaVacía(c); {cola de nodos vivos} añadir(c,<x0,coste(x0)>); éxito:=falso;
mq not éxito and not esVacía(c) hacer xcurso:=min(c); {nodo en curso}
eliminarMin(c);
mq not éxito and
hay otro hijo x de xcurso hacer si esSol(x)

entonces
escribir(x); éxito:=verdad
sino
añadir(c,<x,coste(x)>)
fsi
fmq
fmq;
si not éxito
entonces escribir(“No hay solución”)
fsi
fsi
fin
Comentarios al esquema algorítmico anterior:

▪ Si se desea escribir todo el camino desde la raíz hasta


la solución, cada vez que se añade un nodo a la cola,
hay que guardar en una tabla auxiliar de padres de
nodos ese nodo junto a su padre.

▪ La terminación del algoritmo sólo está garantizada si


el espacio de estados es finito.

▪ Si el espacio de estados es infinito y existe al menos


una solución, se puede garantizar la terminación con
una elección adecuada de la función de estimación.

▪ Si el espacio de estados es infinito y no hay


solución, el algoritmo no termina…

-Se suele restringir la búsqueda a nodos con coste estimado menor que
C.

También podría gustarte