2023-11-11 18:41:34 +00:00
[[algoritmo]] di [[leader election]] che risolve il problema di terminazione della [[leader election su anello all-the-way]].
## [[restrizioni al modello dei sistemi distribuiti|Restrizioni]] aggiuntive
- **[[restrizione di topologia|Topologia]]**
- [[anello]] di ** *dimensione nota***
2023-11-08 04:15:56 +00:00
2023-11-08 18:28:09 +00:00
## [[Comportamento]]
2023-11-08 04:15:56 +00:00
> [!Summary]
> Ogni [[entità]] invia il suo [[identificatore]] alla successiva, e gli inoltra gli identificatori ricevuti dalla precedente, tenendo traccia dell'identificatore minimo ricevuto, ***fino a quando non ne conosce tanti quante le [[entità]] del [[sistema distribuito]]***.
Si può effettuare il conteggio in due modi:
- con un [[contatore]] su ogni [[entità]], che conta il numero di [[messaggio|messaggi]] transitati
2023-11-11 18:41:34 +00:00
- con un [[contatore]] su ogni [[messaggio]], che conta il numero di [[entità]] transitate
2023-11-08 04:15:56 +00:00
## [[algoritmo corretto|Correttezza]]
2023-11-11 18:41:34 +00:00
> [!Success]
> L'algoritmo termina quando tutte le [[entità]] hanno visto tanti [[messaggio|messaggi]] quante le [[entità]] del [[sistema distribuito]].
2023-11-08 04:15:56 +00:00
## [[costo computazionale distribuito|Costo computazionale]]
### [[Comunicazione]]
Ogni [[entità]] invia tanti [[messaggio|messaggi]] quanti le [[entità]] del sistema distribuito, ovvero:
$$
Entity \cdot Entity
$$
In [[notazione asintotica]], è:
$$
\Large O \left( Entity^2 \right)
$$
### [[Spazio]]
Nel caso peggiore, ciascun messaggio contiene tanti [[bit]] quanti quelli dell'identificatore più grande, ovvero, in [[notazione asintotica]]:
$$
\Large O \left( Entity^2 \cdot \log( \max(Identifier) ) \right)
$$
### [[Tempo]]
Nel caso peggiore, solo una [[entità]] è [[iniziatori multipli|iniziatrice]], e in tal caso, dovrà svegliare le altre con il proprio messaggio.
Il messaggio dovrà prima arrivare alla sua precedente, richiedendo:
$$
\color{LightCoral} Entities -1
$$
Poi, il messaggio della precedente dovrà fare un giro completo:
$$
\color{SkyBlue} Entities
$$
Per un totale di:
$$
{\color{LightCoral} Entities -1}
+
{\color{SkyBlue} Entities}
$$
Ovvero:
$$
2 \cdot Entities - 1
$$
Che in [[notazione asintotica]] è:
$$
\Large O(Entities)
$$