Степенной метод

Материал из testwiki
Перейти к навигации Перейти к поиску

Степенной метод, или метод степенных итераций, — итерационный алгоритм поиска собственного значения с максимальной абсолютной величиной и одного из соответствующих собственных векторов для произвольной матрицы.

Алгоритм прост и сходится со скоростью геометрической прогрессии, если все максимальные по модулю собственные значения совпадают, в противном случае сходимости нет. При близких по модулю собственных значениях сходимость может оказаться медленной. В силу того, что алгоритм сводится к последовательному умножению заданной матрицы на вектор, при правильной реализации он хорошо работает для больших разреженных матриц.

Алгоритм предложен в 1929 году Рихардом фон Мизесом и Хильдой Гейрингер[1].

Алгоритм

В начале алгоритма генерируется случайный вектор r0[2]. Далее проводятся последовательные вычисления по итеративной формуле:

rk+1=ArkArk[3]

Если исходный вектор не ортогонален собственному подпространству с наибольшим по модулю собственным значением, то расстояние от элементов данной последовательности до такого подпространства стремится к нулю[4]. Последовательность векторов не всегда сходится, поскольку вектор на каждом шаге может менять знак или в комплексном случае вращаться, но это не мешает выбрать один из векторов в качестве собственного, когда получено достаточно точное собственное значение.

Последовательность

μk=rkTArkrkTrk=(rk,Ark)(rk,rk)

при указанном выше условии сходится к максимальному по модулю собственному значению. Но следует помнить, что не у всех действительных матриц есть действительные собственные значения.

Для нормальных операторов

В частном, но важном случае нормальных операторов все собственные векторы матрицы взаимно ортогональны. В этом случае степенной метод позволяет найти все собственные значения и векторы матрицы.

Пусть rk — нормированный собственный вектор с максимальным по модулю собственным значением матрицы A нормального оператора. Тогда матрица

A1=AλrkrkT

сохраняет все собственные векторы матрицы A, кроме вектора rk, и позволяет искать степенным методом следующий собственный вектор с максимальным по модулю собственным значением.

Доказательство сходимости

Упорядочим собственные значения по невозрастанию абсолютной величины и допустим, что λ1>λ2...λn[5]. Тогда начальный вектор можно представить как

r0=i=1nvi+w,

где vi — собственные векторы, вектор w обнуляется при первом умножении на матрицу, а v10 по предположению.

Рассмотрим результат k умножений матрицы на начальный вектор:

Rk=Ak(i=1nvi+w)=i=1nλikvi=λ1k(v1+O((λ2λ1)k).

Поделив левую и правую часть на Rk, получим

rk=λ1v1λ1v1+O((λ2λ1)k).

Приложения

Метод применяется в первую очередь для разреженных матриц. Например, Гугл использует его для расчёта рангов страниц в Интернете[6], а Twitter использует его для рекомендаций «за кем следовать»[7].

Примечания

Шаблон:ПримечанияШаблон:Нет ссылок

  1. Richard von Mises and H. Pollaczek-Geiringer, Praktische Verfahren der Gleichungsauflösung, ZAMM — Zeitschrift für Angewandte Mathematik und Mechanik 9, 152—164 (1929).
  2. В некоторых случаях есть возможность использовать уже имеющееся приближение доминирующего собственного вектора.
  3. Деление (нормировка) в этой формуле нужно, чтобы исключить обнуление или переполнение координат вектора и при ориентировочно известных собственных значениях его не обязательно делать на каждом шаге.
  4. В случае, когда наибольшее по модулю собственное значение — положительное вещественное число, данная последовательность векторов также сходится к некоторому собственному вектору.
  5. Допущение сделано для сокращения выкладок. В случае нескольких совпадающих собственных значений максимальных по модулю доказательство аналогично.
  6. Шаблон:Cite news
  7. Pankaj Gupta, Ashish Goel, Jimmy Lin, Aneesh Sharma, Dong Wang, and Reza Bosagh Zadeh WTF: The who-to-follow system at Twitter Шаблон:Wayback, Proceedings of the 22nd international conference on World Wide Web