• Aucun résultat trouvé

Am´eliorer l’efficacit´e du routage grˆace `a une exploration restreinte 28

Pour rechercher des am´eliorations de l’efficacit´e du routage glouton, nous commenc¸ons par revenir sur son analyse. L’analyse globale du routage glouton G entre une source et une cible `a distance δ se fait par dichotomie : on d´ecoupe l’ex´ecution de l’algorithme enlog δ phases correspondant aux divisions succes-sives de la distance courante par deux. Lai-`eme phase, 1 6 i 6 log δ, dure tant que la distance du porteur courant du message (i.e. le noeud courant trait´e par l’al-gorithme) `a la cible appartient `a(2i−1, 2i]. On peut alors montrer qu’en phase i, la probabilit´e que le j-`eme contact longue-distance du porteur courant du message soit `a distance strictement inf´erieure `a2i−1de la cible est sup´erieure `a1/(c log n), o`uc est une constante strictement positive, pour tout 1 6 j 6 k. On en d´eduit que l’esp´erance du nombre de noeuds visit´es parG durant la i-`eme phase d’ex´ecution est O ((log n)/k). En sommant sur toutes les phases, on obtient l’esp´erance de

2.2 : Am´eliorer l’efficacit´e du routage grˆace `a une exploration restreinte 29

longueur totale du chemin de routage :O ((log n log δ)/k).

La cl´e de cette analyse est la bonne r´epartition des liens longue-distance sur toutes les ´echelles de distance, dans le mod`ele de Kleinberg. Cette r´epartition garantit qu’en visitant Ω ((log n)/k) nouveaux noeuds en esp´erance, `a distance comprise entre x et x/2 de la cible du routage, on trouve un contact longue-distance qui est `a longue-distance strictement inf´erieure `a x/2 de la cible, pour tout x inf´erieur ou ´egal `a n. La visite gloutonne d’un ensemble de noeuds de taille S allonge de S la longueur du chemin de routage. Nous pouvons chercher `a visiter ces noeuds de fac¸on plus compacte, afin de diminuer la longueur du chemin n´ecessaire pour trouver un contact deux fois plus proche de la cible. Une id´ee naturelle est de construire une exploration arborescente, c’est-`a-dire de visiter un voisinage de noeuds autour du noeud courant en suivant les liens locaux et longue-distance des voisins, de proche en proche. Chaque noeud du mod`ele ayant un degr´e sortant constant, on peut penser visiter de cette fac¸on Ω ((log n)/k) nouveaux noeuds (i.e. non visit´es) avec une profondeur d’explo-ration Θ (log ((log n)/k)). Toutefois, les contacts longue-distance des voisins peuvent ˆetre des noeuds pr´ec´edemment visit´es par l’algorithme. On rencontre alors des probl`emes de d´ependance des tirages des liens et les branches de l’arbre ne sont pas disjointes, ce qui r´eduit le nombre de nouveaux noeuds contenus dans l’ensemble explor´e. Dans les sections suivantes, nous allons ´etudier comment parvenir `a r´esoudre ces probl`emes de d´ependance pour construire une structure d’exploration compacte et contenant suffisamment de nouveaux noeuds.

Principe g´en´eral de l’algorithme. Pour une source et une cible donn´ee, notre algorithme va construire des structures d’explorations successives des contacts locaux et longue-distance, dont la profondeur d´epend de la distance courante `a la cible. `A la fin de chaque exploration, le message `a transmettre est envoy´e de la racine de l’exploration au noeud le plus proche de la cible, parmi les noeuds explor´es. Nous faisons l’hypoth`ese que la d´ecouverte d’un lien longue-distance lors de l’exploration nous autorise `a renvoyer une faible quantit´e d’information en sens inverse sur ce lien, ce qui permet `a la racine de d´eterminer le noeud le plus proche de la cible dans l’ensemble explor´e. En revanche, le message `a transmettre emprunte les liens longue-distance suivant leur orientation. Cette hypoth`ese peut s’illustrer par le passage d’une lettre dans un r´eseau social : supposons que Ringo connaˆıt John mais que John ne connaˆıt pas Ringo ; si Ringo envoie une lettre `a John en indiquant son adresse au dos de l’enveloppe (d´ecouverte du lien longue-distance), John peut alors envoyer une lettre `a Ringo. On peut ´egalement illustrer ce fait par la navigation dans le r´eseau des pages web : supposons que la page web de Germaine pointe sur celle du groupe The Beatles, sans que celle-ci ait un hyperlien vers la page de Germaine ; un internaute passant de la page de Germaine `a la page des Beatles par l’hyperlien (d´ecouverte du lien longue-distance) peut

revenir sur la page de Germaine par la touche « back »du navigateur.

2.2.1 Compromis entre le recoupement et la profondeur

d’ex-ploration

Dans cette section, nous ´etudions les marges d’optimisation offertes par une exploration des contacts locaux et longue-distance `a partir d’un noeud. On se donne une source et une cible pour le routage, et l’on note x la distance sous-jacente d’un noeud x `a la cible.

On consid`ere `a pr´esent le noeud x qui est la racine de notre structure d’explo-ration. Pour faciliter la lecture, nous allons repr´esenter la structure d’exploration par un arbre. Les branches sont les chemins constitu´es de liens locaux et longue-distance des noeuds explor´es, l’ensemble des fils d’un noeud est constitu´e de l’en-semble de ses contacts locaux et longue-distance qui sont plus proches de la cible que la racine.

Nous avons vu que, dans cet arbre, les branches ne sont pas disjointes. On distingue deux cas de recoupements :

-1ercas : le contact d’un noeud est un noeud d´ej`a pr´esent dans la structure d’exploration,

-2`eme cas : le contact d’un noeud est `a distance strictement sup´erieure `a x de la cible. En effet, un noeud `a distance strictement sup´erieure `a x de la cible peut avoir ´et´e visit´e par l’algorithme dans les phases pr´ec´edentes, son ind´ependance n’est pas garantie.

Chaque recoupement ´elimine de la structure arborescente tout le sous-arbre qui y est enracin´e. Cela diminue donc le nombre total de noeuds ; toutefois, ces noeuds sont des r´ep´etitions, et leur visite est donc inutile dans la recherche d’un contact deux fois plus proche de la cible. Un exemple d’exploration est illustr´e sur la figure 2.1. Pour augmenter le nombre de noeuds de la structure et compenser les recoupements, on peut augmenter la profondeur de l’exploration. Toutefois, dans le but de diminuer la longueur totale du chemin de routage, la profondeur de l’exploration doit ˆetre limit´ee, puisqu’elle repr´esente la longueur du morceau de chemin que l’on ajoute au chemin courant `a chaque phase de division par deux de la distance `a la cible. Il s’agit donc d’arriver `a un compromis entre une profondeur d’exploration restreinte et un nombre de nouveaux noeuds suffisamment grand.

Dans la suite, nous allons quantifier pr´ecis´ement la probabilit´e de recoupe-ment des voisins qui nous permet de minorer le nombre de nouveaux noeuds dans l’arbre, pour chaque profondeur, avec une certaine probabilit´e. Nous verrons que cette m´ethode seule ne permet pas d’obtenir une profondeur d’exploration suffisamment faible tout en garantissant Ω ((log n)/k) nouveaux noeuds dans la structure. Afin d’augmenter le nombre de nouveaux noeuds dans la structure, en

2.2 : Am´eliorer l’efficacit´e du routage grˆace `a une exploration restreinte 31 0 1 2 3 4 5 6 7 8 profondeur d'exploration = 3 noeud racine 3 4 5 6 4 2 3 5 2 6 3 3 6 6 3 3 4 5 6 t Arbre d'exploration avec recoupements Arbre d'exploration après retrait des recoupements

FIG. 2.1 : Arbre d’exploration de profondeur 3 dans un r´eseauK1

1,n, `a partir du noeud racine3 et que l’on a dirig´e vers la cible t. En gras et en pointill´es figurent les liens longue-distance, les pointill´es correspondent aux recoupements.

augmentant tr`es peu la profondeur de la structure, nous la prolongeons par des chaˆınes de liens locaux dirig´ees vers la cible, enracin´ees aux feuilles de l’arbre (cf. figure 2.2). Tant que l’on garantit que ces chaˆınes ne recoupent pas les autres noeuds de la structure, l’ajout de ces chaˆınes multiplie le nombre de nouveaux noeuds pr´esents dans la structure (les feuilles) par la longueur des chaˆınes. D´efinition 2.1 (Chaˆıne)

On appelle chaˆıne, un chemin constitu´e uniquement de liens locaux.

2.2.2 Lien valideet zone de s´ecurit´e

Cette section introduit dans notre vocabulaire les termes lien valide et zone de

s´ecurit´e, relatifs `a la gestion des recoupements, afin de simplifier la description de

notre algorithme dans la suite.

Afin de garantir l’ind´ependance de la structure d’exploration courante vis-`a-vis des noeuds visit´es dans une structure d’exploration pr´ec´edemment visit´ee, nous ne consid´erons que les contacts qui sont strictement plus proches de la cible que leur origine. On appelle liens valides les liens associ´es, d´efinis formellement ci-dessous.

}

}

Exploration

Chaînes de liens locaux (noeuds non visités)

FIG. 2.2 : Exemple d’arbre d’exploration de profondeur 3 avec ses chaˆınes de liens locaux de longueur3 attach´ees aux feuilles, dans un r´eseauK1

1,n. D´efinition 2.2 (Lien valide)

On dit qu’un lien (local ou longue-distance) d’un noeud u vers un noeud v est

valide si v est strictement plus proche de la cible que u selon la distance de

Man-hattan. On dit alors que v est un contact valide (local ou longue-distance) de u. On dit qu’un noeud v est `ah liens valides de u, s’il existe un chemin de longueur

inf´erieure ou ´egale `ah de u vers v compos´e uniquement de liens valides.

On dit que v est `ah liens locaux valides de u si ce chemin est uniquement

com-pos´e de liens locaux valides.

Supposons que la structure d’exploration est compos´ee de liens locaux et longue-distance et prolong´ee par des chaˆınes de liens locaux enracin´ees en cha-cune de ses feuilles, comme d´ecrit dans la section pr´ec´edente.

Afin de garantir que les chemins de liens locaux de l’arbre (dont les chaˆınes) sont constitu´es de noeuds distincts, il suffit de ne consid´erer dans la structure que les contacts longue-distance qui sont `a une distance sup´erieure ou ´egale `a la hauteur de l’arbre des autres noeuds de la structure. On appelle zone de s´ecurit´e d’un noeud u l’ensemble des noeuds `a distance inf´erieure `a la hauteur de l’arbre de u. On dit que ces noeuds sont interdits pour les contacts longue-distance des autres noeuds de la structure. On remarquera que les contacts longue-distance que l’on ne consid`ere pas sont visit´es par ailleurs dans la structure, puisque ce sont des r´ep´etitions.