Algoritmo de Dijkstra-Lamport
Algoritmo de Dijkstra-Lamport
Algoritmo de Dijkstra-Lamport
Las grficas pueden ser usadas para representar muchos tipos de problemas de enrutamiento, como por ejemplo; una grfica puede representar el sistema de autopistas de un estado de un pas, en donde los vrtices de la grafica representan a las ciudades y las aristas representan las diferentes secciones de autopista. A las aristas se les pueden asignar pesos los cuales pueden ser las distancias entre dos ciudades conectadas por una arista, o tambin puede representar el tiempo de manejo a lo largo de esta seccin de autopista. Otro problema que se podra presentar para este ejemplo es el de un motociclista que desea manejar de la ciudad A a la B el cual est interesado en saber si hay un camino entre esas dos ciudades y si hay ms de un camino, cul es el ms corto. Estos problemas definidos por estas preguntas son casos especiales de encontrar el camino ms corto entre vrtices de una grfica. La longitud de un camino esta ahora definido por la suma de los pesos de las aristas de esos caminos. El vrtice de inicio del camino se refiere a cual es el origen, y el ltimo vrtice a cual es el destino. Para el problema que tomaremos tenemos una grafica G = (V,E), una funcin de peso c(q) para las aristas de G, y un vrtice origen vo. El problema consiste en determinar el camino ms corto de vo a todos los vrtices restantes en la grfica G.(Se asume que todos los pesos son positivos). Para resolver este problema nos basamos en un algoritmo voraz para generar los caminos ms cortos; pero debemos considerar que hay mltiples soluciones para este problema as como tambin mltiples optimizaciones. Un solucin es construir los caminos ms cortos uno por uno. Como una optimizacin podemos usar las sumas de las distancias de todos los caminos ms lejanos generados. Para optimizar lo anterior, cada camino individual debe ser de mnima longitud. Si ya hemos construido i caminos ms cortos, despus usamos esta optimizacin, en prximo camino a ser construido debe ser el prximo camino con longitud ms corta. Esta forma voraz de generar los caminos ms cortos de vo a el resto de todos los vrtices de una grafica es para generar estos caminos en orden no-decreciente. Primero, generamos en camino ms corto al vrtice ms cercano del origen. Despus se genera el camino ms corto al segundo vrtice mas cercano, y as sucesivamente. En el problema y en el algoritmo la S denota un grupo de vrtices (incluyendo a vo) para los cuales los caminos mas cortos ya fueron generados. Para una w que no esta en S, dist(w) es la longitud del camino mas corto de vo, yendo solo desde estos vrtices que estan en el conjunto S, y terminan en w. Pero debemos tener en cuenta lo siguiente: - Si el camino mas corto es para un vrtice u, despus el camino empieza en vo, y termina en una u, estos deben de ser solo de los vrtices que estan en S. Para lograr esto, debemos mostrar que todos los vrtices intermedios en el camino ms corto a u, estan en S. Asumimos que este es un vrtice w en este camino que no esta en S. Despus, el camino de vo a u, tambien contiene un camino de vo a w el cual tiene una longitud menor que el camino de vo a u.
- El destino del siguiente camino generado debe de estar en el vrtice u, el cual tiene la minima distancia, dist(u), de entre todos los vrtices que no estan en S. - habiendo seleccionado un vrtice u con la observacin anterior y generado el camino mas corto de vo a u, el vrtice u se convierte en un miembro de S. En este punto la longitud del camino mas corto empieza en vo, yendo solo hacia los vrtices que estan en S y terminando en un vrtice w que no esta en S que puede decrementarse, entonces el valor de su distancia dist(w) puede cambiar. Si cambia, entonces este debe ser debido a que el camino mas corto empieza en vo y va a u y despus a w. Los vrtices intermediarios en vo a u y el camino de u a w deben todos estar en S. Adicionalmente, el camino de vo a u debe ser el camino mas corto a ese vrtice; de otra forma dist(w) no esta definida apropiadamente. Por ultimo podemos concluir que si dist(w) ha cambiado, esto porque el camino de vo a u o w, donde el camino de vo a u es el camino mas corto a ese y el camino de u a w es la arista(u,w). La longitud de este camino es dist(u)+c(u,w). La observacin de arriba nos da una ventaja para un algoritmo simple para una solucion simple del problema de caminos ms cortos. Este problema(conocido como el algoritmo de Dijkstra) solo determina la longitudes de los caminos mas cortos de vo a todos los otros vrtices de una grafica G. Para el algoritmo de Dijkstra se asume que los n vrtices de G estan numerados de u hasta n. El conjunto S se mantiene como un arreglo con S[i]=0 si el vrtice i no esta en S y S[i]=1 si lo esta. Tambien se asume que la grfica que se da esta representada por una matriz adyacente de costos cosy[i][j] siendo los pesos de una arista (i,j). El peso cost[i][j] es el conjunto de algunos numeros grandes, infinito, en caso de que la arista (i,j) no esta en E(G).
ALGORITMO DE DIJKSTRA.
ShotestPaths (int v, flota cost[][SIZE], float dist[], int n) /*dist[j], donde i <= j <=n es el conjunto de las distancias del camino mas corto del vrtice v al vrtice j en una grafica G con n vrtices. Dist[v] es el conjunto de ceros. G esta representada por una matriz adyacente de distancias cost[1...n][1...n]*/ { int u; bool S[SIZE]; for(int i=1; i<=n; i++){ //Se inicializa S.// S[i]=false; dist[i]=cost[v][i]; } S[v]=true; dist[v]=0.0; //Se pone v en S // for(int num=2; num<n; num++){ /*Se determinan n-1 caminos de v. Elegimos u de entre estos vrtices que no estan en S cuya distancia dist[u] es la minima*/ S[u]=true; //Ponemos u en S// For(int w=1; w<=n; w++) //actualizamos distancias// If((S[w]=false) && (dist[w] > dist[u] + cost[u][w])) Dist[w]= dist[u] + cost[u][w]; } }
ALGORITMO DE CHANDY-LAMPORT
La estrategia a menudo llamada snapshots o protocolo de snapshots, consiste en sacarle una fotografa a cada proceso en forma individual. El protocolo de snapshots agrega la nocion de estado del canal, de esta forma un snapshots entrega : el estado del proceso el estado de los canales Se asume canales FIFO y nodos fuertemente conectados (FIFO significa que ningun mensaje adelanta a otro) ALGORITMO Alguien manda una marca por difusin cada proceso Pi hace : (1) Despues de recibir por primera vez una marca, por ejemplo desde Pj hace : Pi registra su estado si Pi registra el canal <Pj, Pi> como vaco (*) Pi pasa la marca a todos sus vecinos (*) * Se hace en forma atmica, es decir nada ms ocurre entre estos dos eventos. (2) Despus de recibir otra vez la marca, digamos desde pk ; hace : pi registra el estado del canal <pk, pi> igual a todos los mensajes recibidos desde pk, desde aquel tiempo en el cual pi registr su estado si hasta aquel tiempo en el cual pi recibi la marca de pk. Esto se realiza para todo pk conectado a pi. Demostracin : Asumir : Alguien empieza el algoritmo La red de comunicacin esta fuertemente conectado (grafo fuertemente conectado). Todos los procesos registran su estado. Cada proceso registra el estado de todos los canales de entrada. Se supone que el estado de todos los procesos puede ser recolectado para formar el estado global S={s1, s2, ..., sn} (1) Algoritmo registra un estado global consistente Dem : Suponga que se registra un estado inconsistente $ Pi, Pj y un mensaje m tal que la marca (enviada por Pi) llega despus de m a Pj