1
Fork 0
mirror of https://github.com/Steffo99/appunti-magistrali.git synced 2024-11-28 21:04:19 +00:00
appunti-steffo/9 - Algoritmi distribuiti/3 - Computazione distribuita/6 - Algoritmi di routing/iterating routing.md

1.7 KiB

algoritmo di routing.

Tip

Simile a FloodMax!

restrizioni al modello dei sistemi distribuiti aggiuntive

comportamento

[!Summary] Ogni router crea una routing table con solo i suoi vicini.

Ad ogni iterazione, la invia a tutti i suoi vicini di un'entità, e riceve contemporaneamente le loro, con cui aggiorna la propria.

algoritmo corretto

[!Success] Dopo tante iterazioni quante il diametro di un grafo della rete di comunicazione, tutti i router avranno aggregato le routing table di tutti gli altri, terminando cosí l'algoritmo.

costo computazionale distribuito

Costo notazione O-grande
comunicazione del routing O(Entities \cdot Channels)
9 - Algoritmi distribuiti/1 - Problemi algoritmici/tempo ...

comunicazione del routing

Note

È un costo diverso dal solito di comunicazione!

Ogni router scambia informazioni con i suoi vicini di un'entità: \color{LightCoral} 2 \cdot Entities

Ad ogni iterazione, ogni router invia la sua routing table ai suoi vicini di un'entità: \sum_{Entity}^{Entities} \sum_{RoutingEntry}^{RoutingEntries} \mathrm{neighbours}(Entity) Cioè: Entities \cdot 2 \cdot Channels Riscritto meglio: \color{SpringGreen} 2 \cdot Entities \cdot Channels

In totale: {\color{LightCoral} 2 \cdot Entities} + {\color{SpringGreen} 2 \cdot Entities \cdot Channels} In notazione asintotica: \Large O(Entities \cdot Channels)