对于一组向量,有时候我们需要对其进行正交化处理,也就是说,该组向量中任意两个向量都是互相垂直的。那么,要怎么做呢?
假设只有两个向量,(vec v_0)和(vec v_1),正交化的几何示意图如下所示。
假设正交化之后的向量为(vec w_0)和(vec w_1),那么由图可知,可得(vec w_0 = vec v_0),且有:
(vec w_1 = vec v_1 - dfrac{vec v_1 cdot vec w_0}{|vec w_0|})
这里减去的部分是向量(vec v_1)在向量(vec w_0)上的投影。然后将(vec w_0)和(vec w_1)进行归一化,就得到了最终的结果。
那么,如果有三个向量,(vec v_0),(vec v_1),(vec v_2),这种情况要如何处理呢?同样地,正交化的几何示意图如下所示。
假设正交化之后的向量为(vec w_0),(vec w_1),(vec w_2),由图可知,可得(vec w_0 = vec v_0),且有:
(vec w_1 = vec v_1 - dfrac{vec v_1 cdot vec w_0}{|vec w_0|})
(vec w_2 = vec v_2 - dfrac{vec v_2 cdot vec w_0}{|vec w_0|} - dfrac{vec v_2 cdot vec w_1}{|vec w_1|})
从图中可以看出向量(vec w_2)即为向量(vec v_2)减去在(vec w_0)和(vec w_1)上的投影。将这三个向量进行归一化即可得到最终的结果。
那么,假如我们有一组向量({ vec v_0, vec v_1, vec v_2, ..., vec v_n }),要想求得它们正交化后的向量组({ vec w_0, vec w_1, vec w_2, ..., vec w_n }),步骤如下:
- 令(vec w_0 = vec v_0);
- 计算(vec w_i = vec v_i - sum_{j = 0}^{i - 1} dfrac{vec v_i cdot vec w_j}{|vec w_j |};1 leq i leq n);
- 将得到的({ vec w_0, vec w_1, vec w_2, ..., vec w_n })进行正交化。