外观
geometric-algebra-primer.md---
title: 几何代数介绍
createTime: 2025/9/7
categories:
- study
tags:
- maths
---
## 点乘和叉乘的局限性
在中学阶段,我们已经掌握了向量的加法、数乘和点乘。可能还会接触到叉乘。向量是研究几何的一个强有力的工具,然而点乘和叉乘却有很多的局限性。比如说:
- 任意两个向量的点乘都是一个标量,损失了很多信息;
- 叉乘只在三维(或七维)中存在,无法扩展到其他维度;
- 点乘和叉乘并不统一,有时需要同时处理两种乘法。
并且,**点乘和叉乘都没有结合律**。这意味着,在这两种乘法下,向量甚至不能构成一个环[+ring]。
这些局限性使我们迫切地想要定义一种新的向量乘法,修补这些漏洞,同时也能正确地在任意维度下沟通几何与代数。
[+ring]:
环要求加法具有零元、逆元、交换律、结合律,
乘法具有单位元、结合律以及对加法的分配律。
## 几何积
### 几何积的诞生
现在,让我们来从头发明一遍几何积。首先,我们要知道我们想要的乘法是什么样子的。
例如,它必须具有**分配律和结合律**。这是任何一个合格的“乘法”都必须具备的。正是因为有了这些性质,我们才能像数字一样对几何对象进行代数运算。
但现有的性质还无法定义出一个实用的乘法。为了兼容点积,我们定义对于向量 $\mathbf{v}$,$\mathbf{v}^2 = |\mathbf{v}|^2$[+square-def]。
我们将具有以上三种性质的乘法叫作向量的**几何积**。
[+square-def]: 这里的定义形式与 Clifford 代数保持一致。
### 反交换律
既然乘法是一种二元运算(两个向量必然共面),我们就可以从二维空间中推导它的其它性质。
对于二维的单位正交基底 $\mathbf{i}, \mathbf{j}$,由于分配律,我们有 $(\mathbf{i} + \mathbf{j})^2 = \mathbf{i}^2 + \mathbf{j}^2 + \mathbf{i}\mathbf{j} + \mathbf{j}\mathbf{i} = 2 + \mathbf{i}\mathbf{j} + \mathbf{j}\mathbf{i}$。
而由于 $|\mathbf{i} + \mathbf{j}| = \sqrt{2}$,则有 $(\mathbf{i} + \mathbf{j})^2 = (\sqrt{2})^2 = 2$。
这表明,$\mathbf{i}\mathbf{j} + \mathbf{j}\mathbf{i} = 0$。这就是正交向量遵守的**反交换律**。
#### 反交换律的推论
1. 对于多个正交向量相乘的情况,只需考虑交换相邻项的次数的奇偶性(或者等价地,考察排列的奇偶性),即可知道任意排列各个向量后,几何积的符号是否改变。
2. 正交单位向量之积的平方的计算:
$$\begin{align*} (\mathbf{v}_1 \mathbf{v}_2 \cdots \mathbf{v}_k)^2 &= (-1)^{k-1} (\mathbf{v}_1 \mathbf{v}_2 \cdots \mathbf{v}_{k-1} \mathbf{v}_k) (\mathbf{v}_k \mathbf{v}_1 \mathbf{v}_2 \cdots \mathbf{v}_{k-1}) \\ &= (-1)^{k-1} (\mathbf{v}_1 \mathbf{v}_2 \cdots \mathbf{v}_{k-1}) (\mathbf{v}_1 \mathbf{v}_2 \cdots \mathbf{v}_{k-1}) \end{align*}$$
递归地,$(\mathbf{v}_1 \mathbf{v}_2 \cdots \mathbf{v}_k)^2 = \displaystyle\prod_{i=1}^{k-1} (-1)^i = (-1)^{k(k-1)/2}$。
3. 若一个 $r$ 重向量 $\mathbf{u}$ 和一个 $s$ 重向量 $\mathbf{v}$ 的重叠部分是 $k$ 维的,则 $\mathbf{v}\mathbf{u} = (-1)^{rs-k} \mathbf{u}\mathbf{v}$。
### 逆元
$\mathbf{A}$ 的逆元 $\mathbf{A}^{-1}$ 是指满足 $\mathbf{A}\mathbf{A}^{-1} = 1$ 的元素。
在几何代数里,求逆元非常简单。根据[反交换律的推论](#反交换律的推论),对于正交单位向量 $\mathbf{v}_1, \mathbf{v}_2, \dots, \mathbf{v}_k$ 有
$$
(\mathbf{v}_1 \mathbf{v}_2 \cdots \mathbf{v}_k)^{-1} = (-1)^{k(k-1)/2} \mathbf{v}_1 \mathbf{v}_2 \cdots \mathbf{v}_k
$$
## 多重向量
### 多重向量及其几何意义
在上面的计算中,出现了形如 $\mathbf{i}\mathbf{j}$ 的式子。它在几何代数中不能再被化简,而是作为一个新的基存在,这被称为**二重向量**。
二重向量也可以扩展到更高的维度,称为**多重向量**。
对于正交[+orthogonality]的向量 $\mathbf{v}_1, \mathbf{v}_2, \dots, \mathbf{v}_k$,它们的几何积 $\mathbf{v}_1 \mathbf{v}_2 \cdots \mathbf{v}_k$ 是一个 $k$ 重向量。
正如向量可以表示有向线段的大小和方向,多重向量表示的是一个 $k$ 维的几何实体的方向以及它的有向面积。
[+orthogonality]: 对于向量非正交的情况,我们在内积(#内积)一章再讨论。
### 多重向量加法的几何意义
以二重向量为例,根据几何积的分配律,有 $\mathbf{i}(\lambda\mathbf{j}+\mu\mathbf{k}) = \lambda\mathbf{i}\mathbf{j} + \mu\mathbf{i}\mathbf{k}$。
而根据向量的正交分解,$\lambda\mathbf{j}+\mu\mathbf{k}$ 在 $\mathbf{j}, \mathbf{k}$ 方向的投影分别是 $\lambda\mathbf{j}$ 和 $\mu\mathbf{k}$,
于是,可以知道 $\mathbf{i}(\lambda\mathbf{j}+\mu\mathbf{k})$ 在 $\mathbf{i}\mathbf{j}$ 和 $\mathbf{i}\mathbf{k}$ 上的投影分别是 $\lambda\mathbf{i}\mathbf{j}$ 和 $\mu\mathbf{i}\mathbf{k}$。
推广这个结论,可以证明:**若干个正交、等维度的多重向量的和生成一个新的多重向量,合多重向量在任何一个分多重向量上的投影都等于这个分多重向量自身。**
## 正交变换的几何代数表示
### 反射
有一个向量 $\mathbf{v}$ 和一个 $k$ 重向量 $\mathbf{B}$,如何计算 $\mathbf{v}$ 关于 $\mathbf{B}$ 的反射?
将 $\mathbf{v}$ 分解成平行于 $\mathbf{B}$ 的 $\mathbf{v}_{\parallel i}$ 和垂直于 $\mathbf{B}$ 的 $\mathbf{v}_{\perp i}$,我们知道反射应当使 $\mathbf{v}_{\parallel i}$ 不变而 $\mathbf{v}_{\perp i}$ 反转。
我们直接不加推导地给出前人的结论
$$\mathbf{v}' = (-1)^{k+1} \mathbf{B} \mathbf{v} \mathbf{B}^{-1}$$
下面来证明它的正确性:
:::note 证明
- 对于 $\mathbf{v}_{\perp i}$:
由于 $\mathbf{v}_{\perp i}$ 和 $\mathbf{B}$ 的重叠部分是零维的,根据[反交换律的推论](#反交换律的推论),
$$(-1)^{k+1} \mathbf{B} \mathbf{v}_{\perp i} \mathbf{B}^{-1} = (-1)^{k+1} \times (-1)^{k-0} \mathbf{v}_{\perp i} \mathbf{B}\mathbf{B}^{-1} = -\mathbf{v}_{\perp i}$$
- 对于 $\mathbf{v}_{\parallel i}$:
由于 $\mathbf{v}_{\parallel i}$ 和 $\mathbf{B}$ 的重叠部分是一维的,
$$(-1)^{k+1} \mathbf{B} \mathbf{v}_{\perp i} \mathbf{B}^{-1} = (-1)^{k+1} \times (-1)^{k-1} \mathbf{v}_{\perp i} \mathbf{B}\mathbf{B}^{-1} = \mathbf{v}_{\perp i}$$
因为几何积的分配律,反射定理对基底成立之后,对任意的向量都成立。
:::
### 旋转
我们都知道,围绕两个夹角为 $\dfrac{\theta}{2}$ 的轴反射两次等价于在两个轴所成的平面上旋转 $\theta$。
设这两个反射轴为 $\mathbf{u}, \mathbf{v}$,于是 $\mathbf{v}\mathbf{u}\mathbf{w}\mathbf{u}^{-1}\mathbf{v}^{-1} = \mathbf{R} \mathbf{w} \mathbf{R}^{-1}$,此处的 $\mathbf{R}$ 是一个二重向量,被称为旋转子。
设旋转平面为 $\mathbf{i}\mathbf{j}$,并且 $\mathbf{u}=\mathbf{i}, \mathbf{v}=\mathbf{i}\cos\dfrac{\theta}{2} + \mathbf{j}\sin\dfrac{\theta}{2}$,此时 $\mathbf{R} = \cos\dfrac{\theta}{2} + \mathbf{j}\mathbf{i} \sin \dfrac{\theta}{2}$。
由于 $(\mathbf{j}\mathbf{i})^2 = -1$,根据欧拉公式[+exp],$\mathbf{R}$ 也可以表示成 $\exp(\mathbf{j}\mathbf{i} \theta/2) = \exp(-\mathbf{i}\mathbf{j} \theta/2)$。
[+exp]: 虽然没有复平面,但是我们仍然可以使用无穷级数定义 $\exp$ 并借以证明几何代数上的欧拉公式。
### 正交变换下的对称性
以上变换 $(-1)^k \mathbf{A} \mathbf{v} \mathbf{A}^{-1}$ 的对称形式告诉我们:几何积在正交变换下具有(反)对称性。
考虑两个向量 $\mathbf{u}, \mathbf{v}$,它们在正交变换 $f$ 之后的几何积满足
$$
\begin{align*}
f(\mathbf{u})f(\mathbf{v}) &= \bigl[ (-1)^k \mathbf{A} \mathbf{u} \mathbf{A}^{-1} \bigr] \ \bigl[ (-1)^k \mathbf{A} \mathbf{v} \mathbf{A}^{-1} \bigr] \\
&= \mathbf{A} \mathbf{u} \mathbf{v} \mathbf{A}^{-1} \\
&= (-1)^k f(\mathbf{u}\mathbf{v})
\end{align*}
$$
事实上,几何代数作为沟通几何与代数的一座重要桥梁,这样的结果是理所当然的。它保证了几何代数的结果不会因为更换手性相同的基底而改变,是几何代数能够在几何中发挥作用的重要条件。
## 几何代数下的其它运算
### 阶
#### 阶的定义
对于一个 $k$ 重向量,它的阶就是 $k$ 我们将 $\mathbf{A}$ 的阶记作 $\operatorname{grade}(\mathbf{A})$。
我们可以用 $\langle \mathbf{A} \rangle_k$ 取 $\mathbf{A}$ 中阶为 $k$ 的部分。
#### 阶容斥原理
定义 $r$ 重向量 $\mathbf{A}$ 和 $s$ 重向量 $\mathbf{B}$ 的交为 $k$ 维的,则由于 $\mathbf{i}^2=1$,有
$$\mathrm{grade}(\mathbf{A}\mathbf{B}) = r + s - 2k$$
由于 $\mathbf{A} \parallel \mathbf{B} \iff k \in \{r,s\}$,也可以得到平行的一个判定
$$\text{grade} (\mathbf{A}\mathbf{B}) = |\text{grade}(\mathbf{A}) - \text{grade}(\mathbf{B})|$$
### 内积
#### 投影
定义 $r$ 重向量 $\mathbf{A}$ 在 $s$ 重向量 $\mathbf{B}$ 上的投影的 $r$ 阶部分为 $\operatorname{proj}_{\mathbf{B}}(\mathbf{A})$。若投影坍缩到不足 $r$ 阶,则 $\operatorname{proj}_{\mathbf{B}}(\mathbf{A}) = 0$。
在[多重向量加法的几何意义](#多重向量加法的几何意义)一章,我们讲过多重向量天然地蕴含着所有投影的信息。因此,我们只需要考虑如何将这个投影信息提取出来即可。
在[阶容斥原理](#阶容斥原理)一章,我们证明了 $\mathbf{A} \parallel \mathbf{B} \iff \text{grade} (\mathbf{A}\mathbf{B}) = |\text{grade}(\mathbf{A}) - \text{grade}(\mathbf{B})|$,因此
$$\operatorname{proj}_{\mathbf{B}}(\mathbf{A}) = \langle \mathbf{A}\mathbf{B} \rangle_{\mathrm{grade}(\mathbf{B}) - \mathrm{grade}(\mathbf{A})} \mathbf{B}^{-1}$$
#### 内积的定义
当 $\mathrm{grade}(\mathbf{B}) \ge \mathrm{grade}(\mathbf{A})$ 时,我们定义 $\mathbf{A} \cdot \mathbf{B} = \mathbf{B} \cdot \mathbf{A} = \operatorname{proj}_{\mathbf{B}}(\mathbf{A})\mathbf{B}$ 是 $\mathbf{A}$ 和 $\mathbf{B}$ 的**内积**,这是内积的几何定义。
容易看出,若 $\mathbf{A}$ 和 $\mathbf{B}$ 都是向量,此时的内积相当于点积。
根据投影公式,$\mathbf{A} \cdot \mathbf{B} = \mathrm{proj}_{\mathbf{B}}(\mathbf{A}) \mathbf{B} = \langle \mathbf{A}\mathbf{B} \rangle_{\mathrm{grade}(\mathbf{B}) - \mathrm{grade}(\mathbf{A})} \mathbf{B}^{-1} \mathbf{B} = \langle \mathbf{A}\mathbf{B} \rangle_{\mathrm{grade}(\mathbf{B}) - \mathrm{grade}(\mathbf{A})}$。这就是内积的代数定义。
### 外积
与内积对应地,$\mathbf{A} \land \mathbf{B} = \langle \mathbf{A}\mathbf{B} \rangle_{\mathrm{grade}(\mathbf{B}) + \mathrm{grade}(\mathbf{A})}$ 是 $\mathbf{A}$ 和 $\mathbf{B}$ 的外积。
外积的几何意义是(多重)向量张成的空间,但是相比于几何积,它要求多重向量必须无交,即
$$
\mathbf{A} \land \mathbf{B} =
\begin{cases}
\mathbf{A}\mathbf{B}, &\text{$\mathbf{A}, \mathbf{B}$ 无交} \\
0, &\text{otherwise}
\end{cases}
$$
但严苛的标准也换来了一个好处:如果用向量的外积表示空间,那么相同的空间永远只差一个常数。