Процесс Грама ― Шмидта
Процесс Грама ― Шмидта преобразует последовательность линейно независимых векторов [math]\displaystyle{ \mathbf{a}_1,\;\ldots,\;\mathbf{a}_n }[/math] в ортонормированную систему векторов [math]\displaystyle{ \mathbf{e}_1,\;\ldots,\;\mathbf{e}_n }[/math], причём так, что каждый вектор [math]\displaystyle{ \mathbf{e}_j }[/math] есть линейная комбинация [math]\displaystyle{ \mathbf{a}_1,\;\ldots,\;\mathbf{a}_j }[/math].
Классический процесс Грама — Шмидта
Алгоритм
Пусть имеются линейно независимые векторы [math]\displaystyle{ \mathbf{a}_1,\;\ldots,\;\mathbf{a}_n }[/math] и пусть [math]\displaystyle{ \mathbf{proj}_{\mathbf{b}}\,\mathbf{a} }[/math] — оператор проекции вектора [math]\displaystyle{ \mathbf{a} }[/math] на вектор [math]\displaystyle{ \mathbf{b} }[/math], определённый как
- [math]\displaystyle{ \mathbf{proj}_{\mathbf{b}}\,\mathbf{a} = {\langle \mathbf{a}, \mathbf{b} \rangle \over \langle \mathbf{b}, \mathbf{b}\rangle} \mathbf{b} , }[/math]
где [math]\displaystyle{ \langle \mathbf{a}, \mathbf{b} \rangle }[/math] — скалярное произведение векторов [math]\displaystyle{ \mathbf{a} }[/math] и [math]\displaystyle{ \mathbf{b} }[/math].
Классический процесс Грама — Шмидта выполняется следующим образом:
- [math]\displaystyle{ \begin{array}{lclr} \mathbf{b}_1 & = & \mathbf{a}_1 & (1) \\ \mathbf{b}_2 & = & \mathbf{a}_2-\mathbf{proj}_{\mathbf{b}_1}\,\mathbf{a}_2 & (2) \\ \mathbf{b}_3 & = & \mathbf{a}_3-\mathbf{proj}_{\mathbf{b}_1}\,\mathbf{a}_3-\mathbf{proj}_{\mathbf{b}_2}\,\mathbf{a}_3 & (3) \\ & \dots & & \\ \mathbf{b}_n & = & \mathbf{a}_n-\mathbf{proj}_{\mathbf{b}_1}\,\mathbf{a}_n - \mathbf{proj}_{\mathbf{b}_2}\,\mathbf{a}_n - \dots - \mathbf{proj}_{\mathbf{b}_{n-1}}\,\mathbf{a}_n & (n) \end{array} }[/math]
На основе каждого вектора [math]\displaystyle{ \mathbf{b}_j \;(j = 1 \ldots n) }[/math] может быть получен нормированный вектор [math]\displaystyle{ \mathbf{e}_j }[/math] единичной длины, определённый как
- [math]\displaystyle{ \mathbf{e}_j = {\mathbf{b}_j\over \| \mathbf{b}_j \|} }[/math]
Результаты процесса Грама — Шмидта:
[math]\displaystyle{ \mathbf{b}_1,\;\ldots,\;\mathbf{b}_n }[/math] — система ортогональных векторов либо
[math]\displaystyle{ \mathbf{e}_1,\;\ldots,\;\mathbf{e}_n }[/math] — система ортонормированных векторов.
Вычисление [math]\displaystyle{ \mathbf{b}_1,\;\ldots,\;\mathbf{b}_n }[/math] носит название ортогонализации Грама — Шмидта, а [math]\displaystyle{ \mathbf{e}_1,\;\ldots,\;\mathbf{e}_n }[/math] — ортонормализации Грама — Шмидта.
Геометрическая интерпретация
Рассмотрим формулу (2) — второй шаг алгоритма. Её геометрическое представление изображено на рис. 1:
- получение проекции вектора [math]\displaystyle{ \mathbf{a}_2 }[/math] на [math]\displaystyle{ \mathbf{b}_1 }[/math];
- вычисление [math]\displaystyle{ \mathbf{a}_2-\mathbf{proj}_{\mathbf{b}_1}\mathbf{a}_2 }[/math], то есть перпендикуляра, которым выполняется проецирование [math]\displaystyle{ \mathbf{a}_2 }[/math] на [math]\displaystyle{ \mathbf{b}_1 }[/math]. Этот перпендикуляр — вычисляемый в формуле (2) вектор [math]\displaystyle{ \mathbf{b}_2 }[/math];
- перемещение полученного на шаге 2 вектора [math]\displaystyle{ \mathbf{b}_2 }[/math] в начало координат. Это перемещение сделано на рисунке лишь для наглядности;
На рисунке видно, что вектор [math]\displaystyle{ \mathbf{b}_2 }[/math] ортогонален вектору [math]\displaystyle{ \mathbf{b}_1 }[/math], так как [math]\displaystyle{ \mathbf{b}_2 }[/math] является перпендикуляром, по которому [math]\displaystyle{ \mathbf{a}_2 }[/math] проецируется на [math]\displaystyle{ \mathbf{b}_1 }[/math].
Рассмотрим формулу (3) — третий шаг алгоритма — в следующем варианте:
- [math]\displaystyle{ \begin{array}{lcr} \mathbf{b}_3 = \mathbf{a}_3-(\mathbf{proj}_{\mathbf{b}_1}\mathbf{a}_3+\mathbf{proj}_{\mathbf{b}_2}\mathbf{a}_3) & & (6) \\ \end{array} }[/math]
Её геометрическое представление изображено на рис. 2:
- получение проекции вектора [math]\displaystyle{ \mathbf{a}_3 }[/math] на [math]\displaystyle{ \mathbf{b}_1 }[/math];
- получение проекции вектора [math]\displaystyle{ \mathbf{a}_3 }[/math] на [math]\displaystyle{ \mathbf{b}_2 }[/math];
- вычисление суммы [math]\displaystyle{ \mathbf{proj}_{\mathbf{b}_1}\mathbf{a}_3 + \mathbf{proj}_{\mathbf{b}_2}\mathbf{a}_3 }[/math], то есть проекции вектора [math]\displaystyle{ \mathbf{a}_3 }[/math] на плоскость, образуемую векторами [math]\displaystyle{ \mathbf{b}_1 }[/math] и [math]\displaystyle{ \mathbf{b}_2 }[/math]. Эта плоскость закрашена на рисунке серым цветом;
- вычисление [math]\displaystyle{ \mathbf{a}_3-(\mathbf{proj}_{\mathbf{b}_1}\mathbf{a}_3 + \mathbf{proj}_{\mathbf{b}_2}\mathbf{a}_3) }[/math], то есть перпендикуляра, которым выполняется проецирование [math]\displaystyle{ \mathbf{a}_3 }[/math] на плоскость, образуемую векторами [math]\displaystyle{ \mathbf{b}_1 }[/math] и [math]\displaystyle{ \mathbf{b}_2 }[/math]. Этот перпендикуляр — вычисляемый в формуле (6) вектор [math]\displaystyle{ \mathbf{b}_3 }[/math];
- перемещение полученного [math]\displaystyle{ \mathbf{b}_3 }[/math] в начало координат. Это перемещение сделано на рисунке лишь для наглядности. Оно не является математическим действием и поэтому не отражается в формуле (6).
На рисунке видно, что вектор [math]\displaystyle{ \mathbf{b}_3 }[/math] ортогонален векторам [math]\displaystyle{ \mathbf{b}_1 }[/math] и [math]\displaystyle{ \mathbf{b}_2 }[/math], так как [math]\displaystyle{ \mathbf{b}_3 }[/math] является перпендикуляром, по которому [math]\displaystyle{ \mathbf{a}_3 }[/math] проецируется на плоскость, образуемую векторами [math]\displaystyle{ \mathbf{b}_1 }[/math] и [math]\displaystyle{ \mathbf{b}_2 }[/math].
Таким образом, в процессе Грама — Шмидта для вычисления [math]\displaystyle{ \mathbf{b}_j }[/math] выполняется проецирование [math]\displaystyle{ \mathbf{a}_j }[/math] ортогонально на гиперплоскость, натянутую на векторы [math]\displaystyle{ \mathbf{b}_1,\;\ldots,\;\mathbf{b}_{j-1} }[/math]. Вектор [math]\displaystyle{ \mathbf{b}_j }[/math] затем вычисляется как разность между [math]\displaystyle{ \mathbf{a}_j }[/math] и его проекцией. То есть [math]\displaystyle{ \mathbf{b}_j }[/math] — это перпендикуляр от [math]\displaystyle{ \mathbf{a}_j }[/math] к гиперплоскости, натянутой на векторы [math]\displaystyle{ \mathbf{b}_1,\;\ldots,\;\mathbf{b}_{j-1} }[/math]. Поэтому [math]\displaystyle{ \mathbf{b}_j }[/math] ортогонален векторам, образующим эту гиперплоскость.
Особые случаи
Процесс Грама — Шмидта может применяться также к бесконечной последовательности линейно независимых векторов.
Кроме того, процесс Грама — Шмидта может применяться к линейно зависимым векторам. В этом случае он выдаёт [math]\displaystyle{ \mathbf{0} }[/math] (нулевой вектор) на шаге [math]\displaystyle{ j }[/math], если [math]\displaystyle{ \mathbf{a}_j }[/math] является линейной комбинацией векторов [math]\displaystyle{ \mathbf{a}_1,\;\ldots,\;\mathbf{a}_{j-1} }[/math]. Для сохранения ортогональности выходных векторов и для предотвращения деления на ноль при ортогонализации алгоритм должен отбрасывать нулевые векторы. Количество векторов, выдаваемых алгоритмом, будет равно размерности подпространства, порождённого векторами (то есть количеству линейно независимых векторов, которые можно выделить среди исходных векторов).
Свойства
- Матрица перехода от [math]\displaystyle{ \mathbf{a}_1,\;\ldots,\;\mathbf{a}_j }[/math] к [math]\displaystyle{ \mathbf{b}_1,\;\ldots,\;\mathbf{b}_j }[/math] — верхнетреугольная матрица.
- Произведение длин [math]\displaystyle{ \mathbf{b}_1,\;\ldots,\;\mathbf{b}_j }[/math] равно объёму параллелепипеда, построенного на векторах системы [math]\displaystyle{ \mathbf{a}_1,\;\ldots,\;\mathbf{a}_j }[/math] как на рёбрах.
- Процесс Грама ― Шмидта для векторов-столбцов матрицы из [math]\displaystyle{ GL(n) }[/math] определяет гомотопическую эквивалентность [math]\displaystyle{ GL(n)\to O(n) }[/math].
Дополнительные толкования
Процесс Грама ― Шмидта может быть истолкован как разложение невырожденной квадратной матрицы в произведение ортогональной (или унитарной в случае эрмитова пространства) и верхнетреугольной матрицы с положительными диагональными элементами ― QR-разложение, что является частным случаем разложения Ивасавы[источник не указан 1878 дней].
Литература
- Беклемишев Д. В. Курс аналитической геометрии и линейной алгебры. — М.: Наука.
Ссылки
- https://www.youtube.com/watch?v=GhhpG1tCQLU Анимация процесса на плоскости
Для улучшения этой статьи желательно: |