Я могу говорить только от Kademlia, может быть, кто-то другой может предоставить более общий ответ. В то же время ...
- d (х, х) = 0
- d (х, у)> 0, если х! = У
Эти две точки вместе, фактически означает, что ближайшая точка до x
составляет x
; все остальные точки дальше. (Это может показаться интуитивным, но другие аспекты метрики XOR не являются.)
В контексте Kademlia это важно, так как поиск узла с ID x
даст этот узел как ближайший. Было бы неудобно, если бы это было не так, поскольку поиск, сходящийся к x
, может не найти узел x
.
- FORALL х, у: д (х, у) = д (у, х)
Структура таблицы маршрутизации Kademlia такова, что узлы поддерживают детальное знание адресное пространство, самое близкое к ним, и экспоненциально уменьшающееся знание более удаленного адресного пространства. Короче говоря, узел пытается сохранить всеk
самые близкие контакты, о которых он слышит.
Симметрия полезна, так как это означает, что каждый из этих ближайших контактов будет поддерживать подробное знание подобной части адресного пространства, а не удаленной части.
Если бы у нас не было этого имущества, было бы полезно подумать о поиске, как о том, как руки часов движутся в одном направлении вокруг часового пояса. Узел в 1 час (Node1) близок к Node2 в 2 часа (30 °), но Node2 далеко от Node1 (330 °). Итак, представьте, что мы ищем двух ближайших к 3 часам (т. Е. Node1 и Node2). Если поиск достигнет Node2, он не будет знать об Node1, поскольку он далеко. Весь поиск и топология должны были бы измениться.
- д (х, г) < = д (х, у) + D (у, г)
Если бы это было не так, то было бы невозможно узел, чтобы узнать, какие контакты из его таблицы маршрутизации возвращаются во время поиска. Он знал бы, что k
ближе всего к цели, но не будет никакой гарантии, что один из других более отдаленных контактов не даст более короткий общий путь.
Из-за этого свойства и однонаправленности различные поиски, начиная с сильно разделенных точек, будут стремиться сходить по тому же пути.
Однонаправленность означает, что ни одно из двух узлов не может иметь одинаковое расстояние от данной точки. Если бы это было не так, то целевая точка могла быть окружена пучком узлов на всем расстоянии от него. Тогда различные различные поиски были бы бесплатными, чтобы выбрать любой из них, чтобы пройти. Однако однонаправленность гарантирует, что именно одна из этих групп будет самой близкой, и любой поиск, который выбирает между этой группой, всегда будет выбирать один и тот же.
Так что это действительно ищет узлы, которые имеют наибольший общий префикс? – amirouche