Метод присоединения соседей (в лингвистике «метод ближайших соседей»[2]) — алгоритм биоинформатики и лингвистики, разработанный Наруя Сайтоу и Масатоси Нэи в 1987 году[3]. Это восходящий кластерный метод для создания филогенетических деревьев. Обычно используется для деревьев, основанных на ДНК или белковых последовательностях, в лингвистике — на данных лексикостатистики, реже фоно- или морфостатистики. Для его реализации необходимо вычислить расстояния между каждой парой таксонов (например, видов или последовательностей)[4].
Ищется пара различных таксонов и (то есть ), для которых значение — наименьшее. Эти таксоны присоединяются к новому узлу, который, в свою очередь, соединяется с центральным узлом. На рисунке справа и присоединены к новому узлу .
Рассчитывается расстояние от каждого из присоединённых таксонов до нового узла.
Рассчитывается расстояние от каждого из оставшихся таксонов до нового узла.
Формируем новую матрицу попарных расстояний: из текущей матрицы удаляем строки и столбцы, соответствующие только что присоединённым таксонам и добавляем новую вершину и, вычисленные в 5 пункте, расстояния.
Повторяем шаги 2 — 5, пока дерево не станет полностью разрешённым и не станут известны длины всех ветвей.
Q-матрица
-матрица рассчитывается по матрице расстояний между таксонами следующим образом[5]:
где − расстояние между таксонами и .
Расстояние между парой присоединённых соседей и новым узлом
Для каждого из присоединённых таксонов используется следующая формула для расчета расстояний до нового узла:
и:
Таксоны и − пара присоединённых таксонов и − новый узел. Ветви и и их длины и − теперь фиксированная часть дерева; они не изменятся и ни на что не повлияют на следующих шагах алгоритма[5].
Расстояние между оставшимися таксонами и новым узлом
Для каждого таксона, не участвовавшего в предыдущем шаге, рассчитывается расстояние до нового узла[5]:
где — новый узел, — узел, до которого мы хотим рассчитать расстояние, и — таксоны только что присоединённой пары.
Сложность
Метод присоединения соседей для таксонов требует итерации[5]. На каждой итерации требуется рассчитать -матрицу. На первом шаге размер -матрицы — , на следующем шаге — и так далее. Реализация алгоритма без оптимизации имеет сложность ; существуют реализации, использующие эвристический подход с меньшим временем выполнения в среднем.
Пример
Предположим, у нас есть пять таксонов со следующей матрицей расстояний:
a
b
c
d
e
a
0
5
9
9
8
b
5
0
10
10
9
c
9
10
0
8
7
d
9
10
8
0
3
e
8
9
7
3
0
По формуле (1) вычислим -матрицу (диагональные элементы матрицы не используются и здесь опущены):
a
b
c
d
e
a
−50
−38
−34
−34
b
−50
−38
−34
−34
c
−38
−38
−40
−40
d
−34
−34
−40
−48
e
−34
−34
−40
−48
Наименьшее значение матрицы , значит к новому узлу присоединяем таксоны и . Вычислим расстояния от и до по формуле (2):
По формуле (3) вычисляем расстояния от новой вершины до оставшихся вершин:
Таким образом, новая матрица попарных расстояний имеет вид:
u
c
d
e
u
0
7
7
6
c
7
0
8
7
d
7
8
0
3
e
6
7
3
0
Соответствующая ей -матрица:
u
c
d
e
u
−28
−24
−24
c
−28
−24
−24
d
−24
−24
−28
e
−24
−24
−28
Теперь наша матрица принимает минимальное значение на двух парах: , и , . Конечное филогенетическое дерево не зависит от того, какую пару мы выберем. Для определённости, выберем и , присоединим их к новому узлу . Как и в первой итерации вычислим расстояния от и до . Они равны и . Расстояния от новой вершины до оставшихся узлов и равны:
Теперь матрица попарных расстояний имеет вид:
v
d
e
v
0
4
3
d
4
0
3
e
3
3
0
Таким образом, мы получили полностью разрешённое дерево. Однако, для полноты стоит провести ещё одну итерацию:
Матрица попарных расстояний:
v
d
e
v
−10
−10
d
−10
−10
e
−10
−10
Выберем пару и и создадим новую вершину . Расстояния до этой вершины от вершин , , равны соответственно:
Матрица смежности:
w
v
d
e
w
0
2
2
1
v
2
0
4
3
d
2
4
0
3
e
1
3
3
0
Таким образом, мы узнали длины всех ветвей и получили полное филогенетическое дерево, показанное на рисунке. Приведённый пример представляет собой идеальный случай: заметим, что если двигаться от одного таксона к другому по ветвям дерева и суммировать длины пройденных ветвей, результат будет равен расстоянию между таксонами в первоначальной матрице расстояний. Например, пройдя от узла к узлу , мы получим . Про матрицу, в которой расстояния согласованы таким образом с каким-либо деревом, говорят, что она аддитивна — свойство, редко встречающееся на практике. Однако важно заметить: если на вход методу присоединения соседей подать аддитивную матрицу расстояний, гарантируется, что в результате работы метода будет построено дерево, согласованное с этой матрицей[3].
Метод присоединения соседей как минимальная эволюция
Метод присоединения соседей можно рассматривать как жадный алгоритм для оптимизации дерева в соответствии с критерием «сбалансированной минимальной эволюции»[6] (БМЭ). Для каждой топологии БМЭ определяет длину дерева (сумму длин ветвей) как взвешенную сумму расстояний из матрицы расстояний, с весами, зависящими от топологии дерева. Оптимальная топология БМЭ — та, при которой длина дерева минимальна. Метод присоединения соседей на каждой итерации соединяет пару таксонов, которые дадут наименьший вклад в длину строящегося дерева. Эта процедура не гарантирует нахождение дерева с топологией, оптимальной по критерию БМЭ, тем не менее, она часто находит оптимальное или близкое к оптимальному дерево.
Достоинства и недостатки
Главное достоинство метода в том, что он быстрый — в частности, из-за того, что алгоритм работает за полиномиальное время[5].
Это делает его приемлемым для анализа больших объёмов данных (сотни или тысячи таксонов)[5] и для бутстрэпа[7]
, для которых использование других методов анализа (например, максимальная экономия, метод максимального правдоподобия) затруднительно с точки зрения количества вычислений[8].
Метод присоединения соседей имеет свойство выдавать правильное дерево на выходе, если на вход подается правильная матрица расстояний. Более того, правильная топология дерева гарантирована, если матрица расстояний «примерно аддитивна», то есть если каждое значение в матрице расстояний отличается от настоящего расстояния менее, чем на половину длины кратчайшей ветви дерева[9].
На практике матрица расстояний редко удовлетворяет этому условию, но метод присоединения соседей часто выдает дерево с правильной топологией в любом случае[10]. Метод присоединения соседей корректно работает с примерно аддитивной матрицей расстояний, потому что она статистически состоятельна для многих эволюционных моделей; имея входные данные подходящей длины, метод с высокой вероятностью восстановит настоящее дерево. По сравнению с UPGMA метод присоединения соседей имеет преимущество: он не предполагает, что все поколения эволюционируют с одинаковой скоростью (гипотеза молекулярных часов).
Тем не менее, вместо метода присоединения соседей часто применяют другие филогенетические методы, не полагающиеся на матрицу расстояний и обеспечивающие бо́льшую точность в большинстве случаев[8].
Реализации и варианты
Существует много программ, реализующих метод присоединения соседей.
RapidNJ и NINJA — быстрые реализации, время работы которых обычно примерно пропорционально квадрату числа таксонов[11][12].
BIONJ и Weighbor — варианты метода присоединения, повышающие его точность путём использования факта, что меньшие расстояния в матрице расстояний обычно лучше изучены, чем большие[13][14].
FastME — реализация близкого метода сбалансированной минимальной эволюции[15].
↑Atteson K. (1997). "The performance of neighbor-joining algorithms of phylogeny reconstruction", pp. 101–110. In Jiang, T., and Lee, D., eds., Lecture Notes in Computer Science, 1276, Springer-Verlag, Berlin. COCOON '97.