Метод итераций Рэлея: различия между версиями
[непроверенная версия] | [непроверенная версия] |
→Преамбула: пунктуация |
→Алгоритм: пунктуация |
||
Строка 4: | Строка 4: | ||
== Алгоритм == |
== Алгоритм == |
||
Как и в обратном степенном методе мы задаём некоторое начальное приближение <math>\mu_0</math> к собственному значению матрицы <math>A</math> и начальный вектор <math>b_0</math>, который может быть либо случайным, либо известным приближением к собственному вектору. Далее итеративно вычисляем новые приближения к собственному вектору <math>b_{i+1}</math> по формуле |
Как и в обратном степенном методе, мы задаём некоторое начальное приближение <math>\mu_0</math> к собственному значению матрицы <math>A</math> и начальный вектор <math>b_0</math>, который может быть либо случайным, либо известным приближением к собственному вектору. Далее итеративно вычисляем новые приближения к собственному вектору <math>b_{i+1}</math> по формуле |
||
<math> |
<math> |
Текущая версия от 16:01, 26 января 2022
Метод итераций Рэлея — итеративный алгоритм вычисления собственных значений и векторов, который дополняет идею обратного степенного метода итеративным вычислением текущего приближения к собственному значению с помощью отношения Рэлея.
Метод Рэлея имеет очень большую скорость сходимости, и часто для получения решения требуется всего лишь несколько итераций. Для симметричных и эрмитовых матриц при достаточно хорошо выбранных начальных значениях сходимость кубическая. Однако время выполнения каждой итерации обычно пропорционально кубу размера матрицы, в то время как для обратного степенного и степенного метода оно квадратично.
Алгоритм
[править | править код]Как и в обратном степенном методе, мы задаём некоторое начальное приближение к собственному значению матрицы и начальный вектор , который может быть либо случайным, либо известным приближением к собственному вектору. Далее итеративно вычисляем новые приближения к собственному вектору по формуле
, где единичная матрица.
В завершение итерации вычисляем следующее приближение к собственному значению с помощью отношения Рэлея:
Пример программной реализации
[править | править код]Ниже приведен пример реализации на языке GNU Octave.
function x = rayleigh(A, epsilon, mu, x)
x = x / norm(x);
% the backslash operator in Octave solves a linear system
y = (A - mu * eye(rows(A))) \ x;
lambda = y' * x;
mu = mu + 1 / lambda
err = norm(y - lambda * x) / norm(y)
while err > epsilon
x = y / norm(y);
y = (A - mu * eye(rows(A))) \ x;
lambda = y' * x;
mu = mu + 1 / lambda
err = norm(y - lambda * x) / norm(y)
end
end
Ссылки
[править | править код]- Lloyd N. Trefethen and David Bau, III, Numerical Linear Algebra, Society for Industrial and Applied Mathematics, 1997. ISBN 0-89871-361-7.
- Rainer Kress, «Numerical Analysis», Springer, 1991. ISBN 0-387-98408-9