Orthogonalization: the Gram-Schmidt procedure
- Orthogonalization
- Projection on a line
- Gram-Schmidt procedure
A basis is said to be orthogonal if
if
. If in addition,
, we say that the basis is orthonormal.
Example: An orthonormal basis in . The collection of vectors
, with
(1)
(2)
forms an orthonormal basis of .
What is orthogonalization?
Orthogonalization refers to a procedure that finds an orthonormal basis of the span of given vectors.
Given vectors , an orthogonalization procedure computes vectors
such that
data:image/s3,"s3://crabby-images/c20ed/c20ed0e64b722e6e03403443ba13a7b38965c5ce" alt="Rendered by QuickLaTeX.com S:= span\{a_1, \cdots, a_k\} = span\{q_1, \cdots, q_r\},"
where r is the dimension of , and
data:image/s3,"s3://crabby-images/b68bd/b68bd326f42e13c21d4c6ea06b5e0ba520a3fa6b" alt="Rendered by QuickLaTeX.com q_i^Tq_j = 0 \hspace{0.05in} (i \neq j), q_i^Tq_i = 1, \hspace{0.05in} 1\leq i, j \leq r."
That is, the vectors form an orthonormal basis for the span of the vectors
.
Basic step: projection on a line
A basic step in the procedure consists in projecting a vector on a line passing through zero. Consider the line
data:image/s3,"s3://crabby-images/4ff38/4ff383073506f065d2f24cd8aff83d6591b0fe59" alt="Rendered by QuickLaTeX.com L(q) := \{tq: t\in \mathbb{R}\},"
where is given, and normalized (
).
The projection of a given point on the line is a vector
located on the line, that is closest to
(in Euclidean norm). This corresponds to a simple optimization problem:
data:image/s3,"s3://crabby-images/d45f2/d45f2783c87895a71cb6e5d273c6416752e5f2ae" alt="Rendered by QuickLaTeX.com \min\limits_{t} ||a-tq||_2"
The vector , where
is the optimal value, is referred to as the projection of
on the line
. As seen here, the solution of this simple problem has a closed-form expression:
data:image/s3,"s3://crabby-images/6d130/6d1309a617f54b84a20162b08660fd4fe2fbbe40" alt="Rendered by QuickLaTeX.com a_{proj} = (q^Ta)q."
Note that the vector can now be written as a sum of its projection and another vector that is orthogonal to the projection:
data:image/s3,"s3://crabby-images/bc9da/bc9dadf4e4b18e38cfd0f5a5df2b6a18cec73cab" alt="Rendered by QuickLaTeX.com a = (a - a_{proj}) + a_{proj} = (a - (q^Ta)q) + (q^Ta)q."
where and
are orthogonal. The vector
can be interpreted as the result of removing the component of
along
.
Gram-Schmidt procedure
The Gram-Schmidt procedure is a particular orthogonalization algorithm. The basic idea is to first orthogonalize each vector w.r.t. previous ones; then normalize result to have norm one.
Case when the vectors are independent
Let us assume that the vectors are linearly independent. The GS algorithm is as follows.
Gram-Schmidt procedure:
- set
.
- normalize: set
.
- remove component of
in
: set
.
- normalize: set
.
- remove components of
in
: set
.
- normalize: set
.
- etc.
![]() |
The image of the left shows the GS procedure applied to the case of two vectors in two dimensions. We first set the first vector to be a normalized version of the first vector ![]() ![]() ![]() ![]() ![]() ![]() |
The GS process is well-defined, since at each step (otherwise this would contradict the linear independence of the
‘s).
General case: the vectors may be dependent
It is possible to modify the algorithm to allow it to handle the case when the ‘s are not linearly independent. If at step
, we find
, then we directly jump at the next step.
Modified Gram-Schmidt procedure:
- set
.
- for
:
- set
.
- if
.
- set
On exit, the integer is the dimension of the span of the vectors
.