Участник:Alexander34396/Обобщенный метод минимальных невязок: различия между версиями

Материал из Алговики
Перейти к навигации Перейти к поиску
Строка 7: Строка 7:
 
=== Математическое описание алгоритма ===
 
=== Математическое описание алгоритма ===
  
Исходные данные:  
+
'''Исходные данные:'''
* система линейных алгебраических уравнений вида <math> Ax = b </math>, где <math> A </math> — невырожденная матрица размера <math>m</math>-на-<math> m </math>;
+
* система линейных алгебраических уравнений вида <math> Ax = b </math>, где <math> A </math> — невырожденная матрица размера <math>n</math>-на-<math> n </math>;
* подпространство Крылова размерности  <math> n </math>, порождённое вектором <math> b </math> и матрицей <math> A </math>:  
+
* подпространство Крылова размерности  <math> m, m <= n </math>, порождённое вектором <math> b </math> и матрицей <math> A </math>:  
:<math> K_n = K_n(A,b) = \operatorname{span} \, \{ b, Ab, A^2b, \ldots, A^{n-1}b \}. \, </math>
+
:<math> K_m = K_m(A,b) = \operatorname{span} \, \{ b, Ab, A^2b, \ldots, A^{m-1}b \}. \, </math>
Вычисляемые данные:  
+
'''Вычисляемые данные:'''
* <math> x_n \in K_n </math> - приближённое решение исходной системы.
+
* <math> x_m \in K_m </math> - приближённое решение исходной системы.
  
Метод GMRES приближает точное решение исходной системы <math> Ax = b </math> вектором <math> x_n \in K_n </math>, минимизирующим Евклидову норму невязки <math>r_n= Ax_n-b</math>.
+
Метод GMRES приближает точное решение исходной системы <math> Ax = b </math> вектором <math> x_m \in K_m </math>, минимизирующим Евклидову норму невязки <math>r_m = Ax_m-b</math>.
  
Для решения исходной системы GMRES, используя <math> l_2 </math>-ортонормальный базис пространства <math> K_n </math>, выполняет поиск приближённого решения <math> x_n </math> в виде:  
+
Для решения исходной системы GMRES, используя <math> l_2 </math>-ортонормальный базис пространства <math> K_m </math>, выполняет поиск приближённого решения <math> x_m </math> в виде:  
:<math> x_n = x_0 + z_n </math>,
+
:<math> x_m = x_0 + z_m </math>,
где <math> x_0 </math> - некоторое начальное приближение, <math> z_n \in K_n </math> - поправка решения.
+
где <math> x_0 </math> - некоторое начальное приближение, <math> z_m \in K_m </math> - поправка решения.
  
Для построения ортонормального базиса <math> K_n </math> метод использует ортогонализацию Арнольди. При введении для базиса <math> K_n </math> матричного обозначения <math> V_n </math> можно записать:  
+
Для построения ортонормального базиса <math> K_m </math> метод использует ортогонализацию Арнольди. При введении для базиса <math> K_m </math> матричного обозначения <math> V_m </math> можно записать:  
:<math> z_n = V_ny_n </math>,  
+
:<math> z_m = V_my_m </math>,  
где <math> y_n \in \mathbb{R}^n </math> - вектор коэффициентов.
+
где <math> y_m \in \mathbb{R}^m </math> - вектор коэффициентов.
  
 
В общем виде алгоритм метода GMRES может быть записан следующим образом:
 
В общем виде алгоритм метода GMRES может быть записан следующим образом:
  
# найти ортонормальный базис <math> V_n </math> подпространства <math> K_n </math> с помощью ортогонализации Арнольди;
+
# найти ортонормальный базис <math> V_m </math> подпространства <math> K_m </math> с помощью ортогонализации Арнольди;
# найти <math> y_n </math>, минимизирующий <math> \|r_n\|_2 </math>;
+
# найти <math> y_m </math>, минимизирующий <math> \|r_m\|_2 </math>;
# посчитать <math> x_n = x_0 + V_ny_n </math>;
+
# посчитать <math> x_m = x_0 + V_my_m </math>;
# повторить, если требуемая точность не была достигнута.
+
# посчитать <math> r_m </math> и остановиться,если требуемая точность была достигнута, иначе повторить.
  
 
=== Вычислительное ядро алгоритма ===
 
=== Вычислительное ядро алгоритма ===
  
 
Вычислительное ядро последовательной версии метода GMRES состоит из двух частей:
 
Вычислительное ядро последовательной версии метода GMRES состоит из двух частей:
* Вычисление ортонормального базиса <math> K_n </math> с помощью ортогонализации Арнольди:
+
* Вычисление ортонормального базиса <math> K_m </math> с помощью ортогонализации Арнольди:  
:: Вычисление <math> (Av_j, v_i) </math>: требует <math> mn + NZ </math> мультипликативных операций, где NZ - количество ненулевых элементов матрицы A.
+
: на одной итерации алгоритма <math> m(m + 1) n + mNZ  </math> мультипликативных операций, где NZ - количество ненулевых элементов матрицы <math> A </math>;
:: Вычисление <math> Av_j - \sum_{i=1}^j (Av_j, v_i)v_{i} </math>: требует <math> mj </math> мультипликативных операций.
+
* Формирование приближенного решения <math> x_0 + V_mY_m </math>:
:: Вычисление <math> \|\hat{v}_{j+1}\|_2 </math>: содержит <math> m </math> мультипликативных операций.
+
: <math>nm</math> мультипликативных операций.
* Формирование приближенного решения Xo+ VkYk
+
 
 +
=== Макроструктура алгоритма ===
  
 
=== Схема реализации последовательного алгоритма ===
 
=== Схема реализации последовательного алгоритма ===
Строка 44: Строка 45:
 
Для решения исходной системы методом GMRES можно воспользоваться следующим алгоритмом:
 
Для решения исходной системы методом GMRES можно воспользоваться следующим алгоритмом:
  
;Подготовка перед итерационным процессом:
+
1 Подготовка перед итерационным процессом:
 +
:1.1 Выбрать начальное приближение <math> x_0 </math>;
 +
:1.2 Посчитать невязку <math> r_0 = b - Ax_0 </math>;
 +
:1.3 Вычислить <math> v_1 = \frac{r_0}{\|r_0\|_2} </math>.
  
# Выбрать начальное приближение <math> x_0 </math>;
+
2 Построение ортонормального базиса <math> K_m </math>:
# Посчитать невязку <math> r_0 = b - Ax_0 </math>;
 
# Вычислить <math> v_1 = \frac{r_0}{\|r_0\|_2} </math>.
 
  
;<math>n</math>-я итерация метода
+
:Для всех <math> j </math> от 1 до m по нарастанию выполнять:
 +
:2.1 <math> h_{ij} := (Av_j, v_i), \quad i=1,\ldots,j </math>;
 +
:2.2 <math> \hat{v}_{j+1} := Av_j - \sum_{i=1}^j h_{ij}v_{i} </math>;
 +
:2.3 <math> h_{j+1j} = \|\hat{v}_{j+1}\|_2 </math>;
 +
:2.4 <math> v_{j+1} = \frac{\hat{v}_{j+1}}{h_{j+1j}} </math>.
  
Построение ортонормального базиса <math> K_n </math>:
+
3 Вычисление приближённого решения <math> x_m </math>:
 +
:3.1 <math> x_m = x_0 + V_my_m </math>, где <math>y_m</math> минимизирует <math>\|r_0 - AV_my_m\|_2</math>;
 +
:3.2 Вычислить <math> r_m </math>;
 +
:3.3 Если требуемая точность достигнута, остановиться.
  
Для всех <math> j </math> от 1 до n по нарастанию выполнять
+
4 Рестарт:
#<math> h_{ij} := (Av_j, v_i), \quad i=1,\ldots,j </math>;
+
:4.1 <math>x_0 = x_m</math>;
#<math> \hat{v}_{j+1} := Av_j - \sum_{i=1}^j h_{ij}v_{i} </math>;
+
:4.2 <math>v_1 = \frac{r_m}{\|r_m\|_2}</math>;
#<math> h_{j+1j} = \|\hat{v}_{j+1}\|_2 </math>;
+
:4.3 Перейти к шагу 2.
#<math> v_{j+1} = \frac{\hat{v}_{j+1}}{h_{j+1j}} </math>.
 
Вычисление приближённого решения <math> x_n </math>:
 
:<math> x_n = x_0 + V_ny_n </math>,
 
где <math>y_n</math> минимизирует <math>\|r_0 - AV_ny_n\|_2</math>.
 

Версия 21:08, 15 октября 2016

1 Свойства и структура алгоритма

1.1 Общее описание алгоритма

Обобщённый метод минимальных невязок (англ. Generalized minimal residual method, GMRES) - итерационный метод численного решения системы линейных алгебраических уравнений с невырожденной матрицей. Метод основан на минимизации квадратичного функционала невязки на подпространствах Крылова. Разработан Юсефом Саадом и Мартином Шульцем в 1986 году как обобщение метода MINRES на случай систем с несимметричными матрицами.

1.2 Математическое описание алгоритма

Исходные данные:

  • система линейных алгебраических уравнений вида [math] Ax = b [/math], где [math] A [/math] — невырожденная матрица размера [math]n[/math]-на-[math] n [/math];
  • подпространство Крылова размерности [math] m, m \lt = n [/math], порождённое вектором [math] b [/math] и матрицей [math] A [/math]:
[math] K_m = K_m(A,b) = \operatorname{span} \, \{ b, Ab, A^2b, \ldots, A^{m-1}b \}. \, [/math]

Вычисляемые данные:

  • [math] x_m \in K_m [/math] - приближённое решение исходной системы.

Метод GMRES приближает точное решение исходной системы [math] Ax = b [/math] вектором [math] x_m \in K_m [/math], минимизирующим Евклидову норму невязки [math]r_m = Ax_m-b[/math].

Для решения исходной системы GMRES, используя [math] l_2 [/math]-ортонормальный базис пространства [math] K_m [/math], выполняет поиск приближённого решения [math] x_m [/math] в виде:

[math] x_m = x_0 + z_m [/math],

где [math] x_0 [/math] - некоторое начальное приближение, [math] z_m \in K_m [/math] - поправка решения.

Для построения ортонормального базиса [math] K_m [/math] метод использует ортогонализацию Арнольди. При введении для базиса [math] K_m [/math] матричного обозначения [math] V_m [/math] можно записать:

[math] z_m = V_my_m [/math],

где [math] y_m \in \mathbb{R}^m [/math] - вектор коэффициентов.

В общем виде алгоритм метода GMRES может быть записан следующим образом:

  1. найти ортонормальный базис [math] V_m [/math] подпространства [math] K_m [/math] с помощью ортогонализации Арнольди;
  2. найти [math] y_m [/math], минимизирующий [math] \|r_m\|_2 [/math];
  3. посчитать [math] x_m = x_0 + V_my_m [/math];
  4. посчитать [math] r_m [/math] и остановиться,если требуемая точность была достигнута, иначе повторить.

1.3 Вычислительное ядро алгоритма

Вычислительное ядро последовательной версии метода GMRES состоит из двух частей:

  • Вычисление ортонормального базиса [math] K_m [/math] с помощью ортогонализации Арнольди:
на одной итерации алгоритма [math] m(m + 1) n + mNZ [/math] мультипликативных операций, где NZ - количество ненулевых элементов матрицы [math] A [/math];
  • Формирование приближенного решения [math] x_0 + V_mY_m [/math]:
[math]nm[/math] мультипликативных операций.

1.4 Макроструктура алгоритма

1.5 Схема реализации последовательного алгоритма

Для решения исходной системы методом GMRES можно воспользоваться следующим алгоритмом:

1 Подготовка перед итерационным процессом:

1.1 Выбрать начальное приближение [math] x_0 [/math];
1.2 Посчитать невязку [math] r_0 = b - Ax_0 [/math];
1.3 Вычислить [math] v_1 = \frac{r_0}{\|r_0\|_2} [/math].

2 Построение ортонормального базиса [math] K_m [/math]:

Для всех [math] j [/math] от 1 до m по нарастанию выполнять:
2.1 [math] h_{ij} := (Av_j, v_i), \quad i=1,\ldots,j [/math];
2.2 [math] \hat{v}_{j+1} := Av_j - \sum_{i=1}^j h_{ij}v_{i} [/math];
2.3 [math] h_{j+1j} = \|\hat{v}_{j+1}\|_2 [/math];
2.4 [math] v_{j+1} = \frac{\hat{v}_{j+1}}{h_{j+1j}} [/math].

3 Вычисление приближённого решения [math] x_m [/math]:

3.1 [math] x_m = x_0 + V_my_m [/math], где [math]y_m[/math] минимизирует [math]\|r_0 - AV_my_m\|_2[/math];
3.2 Вычислить [math] r_m [/math];
3.3 Если требуемая точность достигнута, остановиться.

4 Рестарт:

4.1 [math]x_0 = x_m[/math];
4.2 [math]v_1 = \frac{r_m}{\|r_m\|_2}[/math];
4.3 Перейти к шагу 2.