如无特殊说明, 下文总假定 `V` 是数域 `bbb P` 上的线性空间, `cc A` 是 `V` 上的线性变换, 记为 `cc A in L(V)`.

特征值与特征向量

设 `cc A in L(V)`, 若存在 `lambda in bbb P` 和 `bm x in V\\{bb 0}` 使成立 `cc A bm x = lambda bm x`, 则称 `lambda` 为 `cc A` 的一个特征值 (特征根), `bm x` 是相应于 `lambda` 的一个特征向量. 直观上, `cc A` 把特定方向上的向量 `bm x` 变为原来的 `lambda` 倍.

把 `n` 阶矩阵 `bm A` 视为 `bbb P^n` 上的线性变换, 则可以类似地定义矩阵的特征值与特征向量. 下面会看到, 线性变换的特征值问题与矩阵的特征值问题是完全等价的. 我们将根据需要, 采用矩阵或线性变换的语言进行叙述.

方阵 `bm A` 可逆当且仅当它没有零特征值.

`bm A` 可逆当且仅当方程 `bm(A X) = bb 0 = 0 bm X` 只有零解, 即 `bm A` 没有零特征值.

    设 `bm A` 为方阵, `lambda` 是 `bm A` 的一个特征根, `bm x` 为对应的一个特征向量:
  1. 若 `f(x)` 为多项式, 则 `f(lambda)` 是 `f(bm A)` 的一个特征根, `bm x` 为对应的一个特征向量; 特别地, `c lambda` 是 `c bm A` 的一个特征根, `lambda^k` 是 `bm A^k` 的一个特征根;
  2. 若 `bm A` 可逆, 则 `lambda != 0`, `lambda^-1` 是 `bm A^-1` 的一个特征根, `bm x` 为对应的一个特征向量;
  3. 若 `bm A` 可逆, 则 `|bm A|lambda^-1` 是 `bm A^**` 的一个特征根, `bm x` 为对应的一个特征向量.
    设 `lambda` 为 `bm A` 的一个特征值, `bm x` 是对应的一个特征向量, 则 `bm(A x) = lambda bm x`.
  1. 将 `f` 展开计算可以验证 `f(bm A) bm x = f(lambda) bm x`, 即 `f(lambda)` 为 `f(bm A)` 的特征值, `bm x` 为对应的一个特征向量.
  2. 在等式 `bm(A x) = lambda bm(x)` 两边同时左乘 `bm A^-1` 得 `bm x = lambda bm(A^-1 x)`, 即 `bm(A^-1 x) = lambda^-1 bm x`.
  3. `bm A` 可逆时, `bm A^** = |bm A|bm A^-1`. 由 1, 2 即得结论.

特征多项式

设 `cc A in L(V)` 在基底 `(bm epsi_1, bm epsi_2, cdots, bm epsi_n)` 下的矩阵为 `bm A`. 若 `lambda in bbb P` 为 `cc A` 的一个特征值, 即 `(EE bm x != bb 0)` `cc A bm x = lambda bm x`. 即关于 `bm x` 的方程 `(lambda bb I - cc A)bm x = bb 0` 在 `V` 中有非零解. 这当且仅当关于 `bm X` 的方程 `(lambda bm I - bm A)bm X = bb 0` 在 `bbb P^n` 中有非零解 (此解就是 `bm x` 在给定基底下的坐标). 这当且仅当 `|lambda bm I - bm A| = 0`.

回顾矩阵和行列式的相关运算: 设 `bm A` 为方阵, `bm T` 可逆, `f(x)` 为多项式, 则 `f(bm(T^-1 A T)) = bm T^-1 f(bm A) bm T`, 即矩阵的相似运算和多项式运算可交换; 换言之, 若 `bm A, bm B` 相似, 则 `f(bm A)`, `f(bm B)` 也相似. 此外相似矩阵的行列式相等: `|bm(T^-1 A T)| = |bm T^-1| |bm A| |bm T| = |bm A|`. 取 `f(x) = lambda - x`, 则 `|lambda bm I - bm(T^-1 A T)|` `= |bm T^-1(lambda bm I - bm A) bm T|` `= |lambda bm I- bm A|`. 最后, 对于分块上三角矩阵 `bm U(bm A_1, cdots, bm A_r)`, 有 `|lambda bm I-bm U| = prod_(i=1)^r |lambda bm I-bm A_i|`.

多项式 `Delta_(bm A)(x) := |x bm I - bm A|` 称为 `n` 阶矩阵 `bm A` 的特征多项式. 相似矩阵具有相同的特征多项式, 从而同一个 `cc A in L(V)` 的表示矩阵的特征多项式唯一确定, 称为线性变换 `cc A` 的特征多项式, 记为 `Delta_(cc A)(x)`. 由知, `lambda` 是 `cc A` 的特征值当且仅当它是 `Delta_(cc A)(x)` 的根. 这就是特征值又称特征根的原因. 把特征根 `lambda` 在特征多项式中的重数称为 `lambda` 的代数重数 或简称重数. 如果 `lambda` 不是特征根, 规定重数为 0.

已知 `f(x) = x^n + a_(n-1) x^(n-1) + cdots + a_1 x + a_0`. 由这个行列式例题知道, 下面矩阵的特征多项式恰为 `f(x)`, 称为 `f(x)` 的友阵: `bm F = [ 0, 0, cdots, 0, -a_0; 1, 0, cdots, 0, -a_1; 0, 1, cdots, 0, -a_2; vdots, vdots, , vdots, vdots; 0, 0, cdots, 1, -a_(n-1); ]`.

`n` 阶矩阵 `bm A` 的特征多项式是首一的 `n` 次多项式: `Delta_(bm A)(x) = |x bm I - bm A|` `= x^n - ("tr"bm A) x^(n-1) + cdots + (-1)^n |bm A|`. 若记 `[n] = {1, 2, cdots, n}`, 对任意非空的 `S = {i_1, i_2, cdots, i_k} sube n`, 定义 `Delta(S)` 是 `bm A` 的位于 `i_1, i_2, cdots, i_k` 行和 `i_1, i_2, cdots, i_k` 列的一个 `k` 阶子式, 称为 `bm k` 阶主子式, 则 `Delta_(bm A)(x)` `= x^n + sum_(O/ != S sube [n]) (-1)^k Delta(S) x^(n-k)`.

  1. 记 `bm A = (a_(i j))_(n xx n)`. 把行列式 `|x bm I - bm A|` 展开, 主对角线上 `n` 个元素的乘积 `prod_(i=1)^n (x-a_(i i))` 是展开式中的一项, 其它各项至多含有 `n-2` 个主对角线上的元素作为因子. 因此, 特征多项式的 `n` 次项和 `n-1` 次项全部来自上式, 即 `x^n - x^(n-1) sum_(i=1)^n a_(i i) = x^n -("tr"bm A) x^(n-1)`. 又, 特征多项式的常数项为 `Delta_(bm A)(0) = |-bm A| = (-1)^n |bm A|`.
  2. 分别用 `bm epsi_i`, `bm alpha_i` 表示 `bm I` 和 `bm A` 的第 `i` 列, `i = 1, 2, cdots, n`. 从而 `|x bm I - bm A|` `= |x bm epsi_1-bm alpha_1, cdots, x bm epsi_n-bm alpha_n|`. 任取 `[n]` 的非空子集 `S`, 按如下方法构造行列式 `D`: 记 `D` 的第 `i` 列为 `D_i`, 其中 `D_i = { -bm alpha_i, if i in S; x bm epsi_i, if i !in S; :}` 将 `D` 的含 `x` 的行, 列交换到左上角, 由于交换了偶数次, 行列式的值不变, 有 `D = (-1)^k Delta(S) x^(n-k)`, 其中 `k = |S|`. 由行列式的性质知道, `Delta_(bm A)(x)` 等于 `x^n` 加上所有这样的行列式 `D` 的和, 证毕.

由根与系数关系的 Vieta 定理, 设 `bm A` 在复数域上的 `n` 个特征根为 `x_1, x_2, cdots, x_n`, 则 `sum_(i=1)^n x_i = "tr"bm A`, `quad prod_(i=1)^n x_i = |bm A|`.

设 `n` 阶方阵 `bm A` 的秩 `r lt n`, 则 `bm A` 的所有 `k gt r` 阶主子式等于 0, 从而 `Delta_(bm A)(x)` 所有次数小于 `n-r` 的项的系数等于 0, 即 `bm A` 的零特征根的重数 `ge n-r`.

    低秩矩阵的特征根 设 `n` 阶方阵 `bm A` 的秩 `r le 1`, 则 `bm A` 的零特征根至少有 `n-1` 重, 再由 Vieta 定理, 另一根为 `"tr"bm A`.
  1. 前面已经讨论过 `bm A` 可逆时 `bm A^**` 的特征根; `bm A` 不可逆时, `r_(bm A^**) le 1`, 于是 `bm A^**` 至少有 `n-1` 重的零特征根, 另一根为 `"tr"bm A^**`.
  2. 现在设 `bm A = bm(alpha beta^T)`, 其中 `bm alpha, bm beta` 为 `n` 元列向量, 于是 `r_(bm A) le 1`, `bm A` 至少有 `n-1` 重的零特征根, 另一根为 `"tr"bm A = bm(beta^T alpha) = bm(alpha^T beta)`.

即使矩阵有 `n` 重零特征根, 矩阵也不一定为零. 如 `[0,1;0,0]`.

Cayley-Hamilton 定理

令 `cc A in L(V)`, 称多项式 `f` 为 `cc A` 的一个零化多项式, 如果 `f(cc A) = bb 0`. 称 `f` 为方阵 `bm A` 的一个零化多项式, 如果 `f(bm A) = bm O`. 零多项式是一个平凡的零化多项式.

`f` 是 `bm A in bbb P^(n xx n)` 的一个 `k ge 1` 次的零化多项式当且仅当 `bm A^k` 可以表示为 `bm I, bm A, bm A^2, cdots, bm A^(k-1)` 的线性组合. 因此, 存在次数不超过 `n^2` 的非平凡的零化多项式.

Cayley-Hamilton 定理 `bm A in bbb P^(n xx n)`, 则 `Delta_(bm A)(x)` 是它的一个 `n` 次的零化多项式, 即 `Delta_(bm A)(bm A) = bm O`.

借助下一章 `lambda` 矩阵的概念. 令 `bbb P` 为一数域, 我们可以等同 以多项式为元素的矩阵 `bbb P[lambda]^(n xx n)` 和以矩阵为系数的多项式 `bbb P^(n xx n)[lambda]`. 如 `[lambda^3 + lambda + 1, lambda^2 - lambda + 3; lambda-1,lambda^3 + lambda^2 + 2]` `= lambda^3[1,0;0,1] + lambda^2[0,1;0,1]` `+ lambda[1,-1;1,0] + [1,3;-1,2]`. 令 `bm C(lambda)` 是 `lambda bm I - bm A` 的伴随矩阵, 则 `bm C(lambda)(lambda bm I-bm A) = |lambda bm I-bm A| bm I`. 显然 `bm C(lambda)` 和 `lambda bm I-bm A` 都是 `lambda` 矩阵. 因为 `bm C(lambda)` 的元素是 `lambda bm I-bm A` 各元素的代数余子式, 所以 `bm C(lambda)` 的各元素是次数不超过 `n-1` 的多项式, 可以表示为 `bm C(lambda) = sum_(i=0)^(n-1) lambda^i bm C_i`, 从而 `bm C(lambda)(lambda bm I-bm A)` `= (sum_(i=0)^(n-1) lambda^i bm C_i)(lambda bm I-bm A)`
`= lambda^n bm C_(n-1)` `+ sum_(i=1)^(n-1) lambda^i(bm C_(i-1) - bm C_i bm A)` `- bm (C_0 A)`.
又令 `Delta_(bm A)(lambda) = sum_(i=0)^n a_i lambda^i`, 从而 `|lambda bm I-bm A| bm I` `= Delta_(bm A)(lambda) bm I` `= sum_(i=0)^n lambda^i(a_i bm I)`. 比较式 左右两边 `lambda^i` 次项系数, 有 `bm C_(n-1) = a_n bm I`, `quad -bm(C_0 A) = a_0 bm I`,
`bm C_(i-1)-bm C_i bm A = a_i bm I`, `quad i = 1, cdots, n-1`.
从而 `Delta_(bm A)(bm A)` `= sum_(i=0)^n a_i bm A^i` `= -bm(C_0 A) + sum_(i=1)^(n-1) (bm C_(i-1)-bm C_i bm A) bm A^i` `+ bm C_(n-1) bm A^n` `= bm O`.

    刘国新, 王正攀. 2013. Cayley-Hamilton 定理的一个新证明. 西南师范大学学报 (自然科学版), 38(8), 1-2.
  1. 先证 `bm A` 在复数域上相似于形如 `bm B = [b,**; bb 0, bm B_1]` 的矩阵. 令 `V` 为一 `n` 维复线性空间, `(bm alpha_1, bm alpha_2, cdots, bm alpha_n)` 为 `V` 的基底, `cc A in L(V)` 在该基底下以 `bm A` 为表示矩阵. 由代数学基本定理, `Delta_(bm A)(x)` 在复数域上有根, 记为 `b`. 令 `bm beta_1` 为相应于 `b` 的特征向量, 将它扩充为 `V` 的基底 `(bm beta_1, bm beta_2, cdots, bm beta_n)`, 记 `(cc A bm beta_1, cc A bm beta_2, cdots, cc A bm beta_n)` `= (bm beta_1, bm beta_2, cdots, bm beta_n) bm B`. 则由于 `cc A bm beta_1 = b bm beta_1`, `bm B` 的第一列除了 `b` 之外都为零.
  2. 对 `n` 进行归纳, 当 `n = 1` 时, `Delta_(bm A)(x) = x - bm A` 显然是 `bm A` 的零化多项式. 假设 `n ge 2`, 定理对于任意阶数为 `n-1` 的矩阵都成立, 我们记 1. 中的 `bm B = bm(T^-1 A T)`, 于是 `Delta_(bm B)(x) = (x-b) Delta_(bm B_1)(x)`. 由归纳假设, `Delta_(bm B_1)(bm B_1) = bm O`, 于是 `Delta_(bm B)(bm B)` `= (bm B - b bm I) Delta_(bm B_1)(bm B)`
    `= [0, **; bb 0, bm B_1 - b bm I_(n-1)]` `[Delta_(bm B_1)(b),**; bb 0, bm O]` `= bm O`.
    从而 `Delta_(bm A)(bm A)` `= Delta_(bm B)(bm A)` `= Delta_(bm B)(bm(T B T^-1))` `= bm T Delta_(bm B)(bm B) bm T^-1` `= bm O`.

求 `bm A^n`, 其中 `bm A = [0,1;1,1]`.

`|lambda bm A-bm I|` `= lambda^2-lambda-1`. 由 Cayley-Hamilton 定理, `bm A^2 = bm A + bm I`, 从而 `bm A^(n+2) = bm A^(n+1) + bm A^n`. 这一递推公式类似于 Fibonacci 数列, 注意到初值 `bm A^0 = bm I`, `bm A^1 = bm A`, 得到 `bm A^n = [ F_(n-1),F_n; F_n,F_(n+1); ]`.

求 `bm A^n`, 已知方阵 `bm A` 的特征多项式为 `(lambda-lambda_1)(lambda-lambda_2)`.

由 Cayley-Hamilton 定理, `(bm A-lambda_1 bm I)(bm A-lambda_2 bm I) = bm O`. 先设 `lambda_1 != lambda_2`, 于是 `bm A^n(bm A-lambda_2 bm I) = lambda_1^n(bm A-lambda_2 bm I)`,
`bm A^n(bm A-lambda_1 bm I) = lambda_2^n(bm A-lambda_1 bm I)`.
两式相减得 `bm A^n = 1/(lambda_1-lambda_2) (lambda_1^n(bm A-lambda_2 bm I) -lambda_2^n(bm A-lambda_1 bm I))`. 再看 `lambda_1 = lambda_2 != 0` 的情形. 我们有 `bm A^(n+2) - 2lambda_1 bm A^(n+1) + lambda_1^2 bm A^n = bm O`. 通解为 `bm A^n = lambda_1^n(bm C_1 + n bm C_2)`. 代入 `bm A^0 = bm I`, `bm A^1 = bm A` 得 `bm A^n = lambda_1^n bm I + n lambda_1^(n-1) (bm A-lambda_1 bm I)`. 最后, 若 `lambda_1 = lambda_2 = 0`, 有 `bm A^2 = bm O`, 从而 `bm A^n = bm O` (`n ge 2`).

求 `bm A^100`, 其中 `bm A = [ 1,0,0; 1,0,1; 0,1,0; ]`.

`|lambda bm I - bm A|` `= (lambda-1)(lambda^2-1)`. 由 Cayley-Hamilton 定理, `(bm A-bm I)(bm A^2-bm I) = bm O`, 即 `bm A(bm A^2-bm I) = bm A^2-bm I`. 从而对任意正整数 `n`, `bm A^n(bm A^2-bm I) = bm A^2-bm I`, 即 `bm A^(n+2) = bm A^n + bm A^2-bm I`. 于是 `bm A^100 = bm A^2 + 49(bm A^2-bm I)` `= [ 1,,; 50,1,; 50, ,1; ]`.

矩阵的合成与特征多项式

[来自 我是永远得不到的i] 矩阵 `bm (A B)` 和 `bm (B A)` 有相同的非零特征根. 特别当 `bm A, bm B` 都为方阵时, 它们有相同的特征根.

设 `lambda != 0` 是 `bm (A B)` 的特征根, `bm (A B x) = lambda bm x`. 左乘 `bm B` 得 `bm (B A) (bm (B x)) = lambda (bm (B x))`, 因为 `lambda != 0`, 所以这里 `bm (B x) != 0`, 故 `lambda` 也是 `bm (B A)` 的特征根.
当 `bm A, bm B` 都为方阵时, 若 `0` 是 `bm (A B)` 的特征根, 有 `0 = |bm (A B)| = |bm (B A)|`, 因此 `0` 也是 `bm (B A)` 的特征根.

若 `bm A, bm B` 不是方阵, 则它们未必同时有 `0` 特征根, 如 `[1, 0, 0]` 和 `[1; 0; 0]`. 但它们非零的特征根是相同的.

令 `bm A in bbb P^(m xx n)`, `bm B in bbb P^(n xx m)`, 则 `x^n|x bm I_m - bm(A B)| = x^m|x bm I_n - bm(B A)|`. 特别当 `bm A`, `bm B` 均为 `n` 阶方阵时, `bm (A B)` 和 `bm (B A)` 具有相同的特征多项式.

利用分块乘法 `[bm I,bm O; -bm A,bm I]` `[bm I_n,bm B; bm A,x bm I_m]` `[bm I,-bm B; bm O,bm I]` `= [bm I_n,bm O; bm O,x bm I_m-bm(A B)]`, `|x bm I_m-bm(A B)| = |bm I_n,bm B; bm A,x bm I_m|`. 同理 `|x bm I_n-bm(B A)| = |bm I_m,bm A; bm B,x bm I_n|` (调换行列) `= |x bm I_n,bm B; bm A,bm I_m|`. 所以 `x^n|x bm I_m - bm(A B)|` `= |x bm I_n,x bm B; bm A,x bm I_m|` `= x^m|x bm I_n - bm(B A)|`.

我们利用特征多项式, 重新表述的结论 1:

设 `bm A` 为 `n` 阶方阵, `f` 为多项式, 若 `Delta_(bm A)(x) = prod_(i=1)^n (x-x_i)`, 则 `Delta_(f(bm A))(x) = prod_(i=1)^n (x-f(x_i))`.

令 `g(y) = x - f(y) = c prod_(j=1)^m (y-y_j)`, 其中 `y_1, y_1, cdots, y_m` 是 `g(y)` 在复数域上的 `m` 个根, 计算可知 `|x bm I - f(bm A)|` `= |c prod_(j=1)^m (bm A - y_j bm I)|` `= (-1)^(m n) c^n prod_(j=1)^m |y_j bm I - bm A|` `= (-1)^(m n) c^n prod_(j=1)^m Delta_(bm A)(y_j)` `= (-1)^(m n) c^n prod_(j=1)^m prod_(i=1)^n (y_j-x_i)` `= c^n prod_(i=1)^n prod_(j=1)^m (x_i-y_j)` `= prod_(i=1)^n g(x_i)` `= prod_(i=1)^n (x - f(x_i))`.

若 `n` 阶方阵 `bm A` 可逆, 则 `bm A^-1`, `bm A^**` 可以表示为 `bm A` 的多项式. `bm A` 不可逆时, `bm A^**` 可以表示为 `bm A` 的多项式吗???

令 `Delta_(bm A)(x) = x f(x) + a`, 由 `bm A` 可逆知, `a = (-1)^n |bm A| != 0`. 于是由 Cayley-Hamilton 定理, `bm A f(bm A) + a bm I = Delta_(bm A)(bm A) = bm O`, 即 `bm A^-1 = -a^-1 f(bm A)`. 从而 `bm A^** = |bm A| bm A^-1` 也能表示为 `bm A` 的多项式.

令 `bm A` 可逆, 若 `Delta_(bm A)(x) = prod_(i=1)^n (x-x_i)`, 则 `Delta_(bm A^-1)(x) = prod_(i=1)^n (x-x_i^-1)`, `Delta_(bm A^**)(x) = prod_(i=1)^n (x-|bm A|x_i^-1)`.

计算知 `-a^-1 f(x_i) = -(Delta_(bm A)(x_i)-a)//(a x_i)` `= x_i^-1`. 伴随矩阵的特征根类似.

设 `f(x) = x^3 - x^2 - 2x + 1` 的三个根分别为 `a, b, c`, 求 `f'(a) f'(b) f'(c)`.

记 `f` 的友阵为 `bm A = [0, 0, -1; 1, 0, 2; 0, 1, 1]`, 于是 `bm A` 的特征根为 `a, b, c`. 由于 `f'(x) = 3x^2 -2x -2`, 计算 `bm B = 3 bm A^2 - 2 bm A - 2 bm I` `= [-2, -3, -1; -2, 4, -1; 3, 1, 5]`. 其特征根即为 `f'(a), f'(b), f'(c)`. 于是答案为 `|bm B| = -49`.

最小多项式

令 `cc A in L(V)`, 称 `cc A` 的次数最低的首一的零化多项式为它的最小多项式. 最小多项式是存在唯一的, 记为 `m_(cc A)(x)`. 同理可以定义方阵的最小多项式.

最小多项式的存在性由零化多项式的存在性保证. 下证唯一性, 设 `f, g` 都是 `bm A` 的最小多项式, 记 `del f = del g = r`, 则 `f-g` 是 `bm A` 的一个次数小于 `r` 的零化多项式. 由 `f, g` 的最小性知 `f-g = 0`.

`f` 是 `bm A` 的零化多项式当且仅当 `m_(bm A) | f`.

充分性显然, 下证必要性. 令 `f(x) = m_(bm A)(x) q(x) + r(x)`, `quad r(x) = 0`, 或 `del r(x) lt del m_(bm A)(x)`. 将 `bm A` 代入知 `r(bm A) = bm O`. 由 `m_(bm A)(x)` 的最小性知 `r(x) = 0`, 即 `m_(bm A) | f`.

由 Cayley-Hamilton 定理, `m_(bm A) | Delta_(bm A)`.

分块对角矩阵 `bm A = "diag"(bm A_1, cdots, bm A_r)` 的最小多项式是各子块的最小多项式的首一的最小公倍式: `m_(bm A)(x) = [m_(bm A_1)(x), cdots, m_(bm A_r)(x)]`. 特别, 对角矩阵 `"diag"(a_1, cdots, a_n)` 的最小多项式是 `prod_(i=1)^r (x-d_i)`, 其中 `{d_1, d_2, cdots, d_r}` `= {a_1, a_2, cdots, a_n}`, 且 `d_1, d_2, cdots, d_r` 两两不同.

相似矩阵具有相同的最小多项式.

由线性变换在不同基底下的矩阵相似即得证. 但是也可以证明如下: 设 `bm B = bm(T^-1 A T)`, 则 `m_(bm A)(bm B) = m_(bm A)(bm(T^-1 A T))` `bm T^-1 m_(bm A)(bm A) bm T` `= bm O`. 从而 `m_(bm A)` 是 `bm B` 的零化多项式. 同理 `m_(bm B)` 是 `bm A` 的零化多项式. 于是 `m_(bm A) | m_(bm B)`, `m_(bm B) | m_(bm A)`. 但两个多项式是首一的, 所以它们相等.

相似矩阵具有相同的特征多项式和最小多项式, 但是反之不成立. 如 `bm A = [1,0;0,1]`, `quad bm B = [1,1;0,1]`, 有 `Delta_(bm A)(x) = Delta_(bm B)(x) = (x-1)^2`, 但与单位阵相似的矩阵只有自身, 所以 `bm A, bm B` 不相似. 又 `bm A = "diag"(1,1,2)`, `bm B = "diag"(1,2,2)`, 则 `m_(bm A)(x) = m_(bm B)(x) = (x-1)(x-2)`, 但 `Delta_(bm A)(x) != Delta_(bm B)(x)`, 所以它们不相似. 我们似乎缺少一个判定矩阵相似的充要条件, 这个问题将在 `lambda` 矩阵的章节解决.

设 `lambda` 为 `n` 阶方阵 `bm A` 的一个特征根, 则 `m_(bm A)(lambda)` 是 `m_(bm A)(bm A) = bm O` 的特征根, 即 `m_(bm A)(lambda) = 0`. 因此 `m_(bm A)(x)` 与 `Delta_(bm A)(x)` 在 `bbb P` 中的根是一样的 (重数可能不同). 特别当 `bm A` 有 `n` 个互异特征根时, `m_(bm A)(x) = Delta_(bm A)(x)`.

令 `bm A` 为方阵, 则 `Delta_(bm A^T)(x) = Delta_(bm A)(x)`, `m_(bm A^T)(x) = m_(bm A)(x)`. `bm A` 和 `bm A^T` 的特征向量有什么关系???

  1. `Delta_(bm A)(x)` `= |x bm I-bm A|` `= |(x bm I-bm A)^T|` `= |x bm I-bm A^T|` `= Delta_(bm A^T)(x)`.
  2. `m_(bm A)(bm A^T)` `= (m_(bm A)(bm A))^T` `= bm O^T = bm O`, 这推出 `m_(bm A^T)(x) | m_(bm A)(x)`, 同理 `m_(bm A)(x) | m_(bm A^T)(x)`, 因此它们相等.

矩阵的对角化

本节讨论矩阵的 (相似) 对角化问题. 从线性变换的角度来看, 即线性变换何时有对角形表示矩阵的问题.

从特征向量来看

`cc A in L(V)` 有对角形表示矩阵当且仅当它有 `n = "dim"V` 个线性无关的特征向量.

设 `cc A` 有线性无关的特征向量 `bm v_1, cdots, bm v_n`, 其中 `cc A bm v_i = lambda_i bm v_i`, `quad i = 1, 2, cdots, n`. 从而线性变换在该基底下的矩阵为 `"diag"(lambda_i)`. 反之, 若线性变换在某基底下的矩阵为 `"diag"(lambda_i)`, 则该基底恰由 `cc A` 的 `n` 个线性无关的特征向量构成.

矩阵的特征值分解 设方阵 `bm A` 有 `n` 个线性无关的特征向量 `bm V = (bm v_1, cdots, bm v_n)`, 其对应的特征值为 `lambda_1, cdots, lambda_n`, 则 `bm A = bm (V Lambda V)^-1`. 其中 `bm Lambda = "diag"(lambda_1, cdots, lambda_n)`.

直接计算 `bm(A V)` `= bm A(bm v_1, cdots, bm v_n)` `= (lambda_1 bm v_1, cdots, lambda_n bm v_n)` `= bm(V Lambda)`. 即 `bm A = bm(V Lambda V)^-1`.

把 `bm A` 看作线性变换 `cc A` 在自然基底 `(bm epsi_1, cdots, bm epsi_n)` 下的表示矩阵. `bm V` 恰为两基底间的过渡矩阵: `(bm v_1, cdots, bm v_n) = (bm epsi_1, cdots, bm epsi_n) bm V`. 因此 `cc A` 在基底 `(bm v_1, cdots, bm v_n)` 下的表示矩阵为 `bm Lambda = bm V^-1 bm A bm V`. 因为 `bm v_1, cdots, bm v_n` 是线性无关的特征向量, 由 知道 `bm Lambda` 为对角形.

设 `cc A in L(V)` 有 `r` 个不同的特征值 `{lambda_i}_(i=1)^r`, 对应于每个 `lambda_i`, 有 `n_i` 个线性无关的特征向量 `{bm alpha_(i j)}_(j=1)^(n_i)`, `i = 1, 2, cdots, r`. 则全部 `n = sum_(i=1)^r n_i` 个特征向量线性无关.

对 `r` 作归纳. `r = 1` 时结论显然成立. 假设结论对 `r-1 ge 1` 成立, 考察 `r` 的情形. 若 `bb 0 = sum_(i=1)^r sum_(j=1)^(n_i) k_(i j) bm alpha_(i j)`, `bb 0 = cc A bb 0 - lambda_r bb 0` `= sum_(i=1)^r lambda_i sum_(j=1)^(n_i) k_(i j) bm alpha_(i j)` `- lambda_r sum_(i=1)^r sum_(j=1)^(n_i) k_(i j) bm alpha_(i j)` `= sum_(i=1)^(r-1) (lambda_i - lambda_r) sum_(j=1)^(n_i) k_(i j) bm alpha_(i j)`. 由归纳假设, `bm alpha_(1 1), cdots, bm alpha_(1 n_1), cdots, bm alpha_(r-1,1), cdots, bm alpha_(r-1, n_(r-1))` 线性无关, 又特征值两两不同, 有 `lambda_i-lambda_r != 0`, `i = 1, 2, cdots, r-1`. 故 `k_(i j) = 0`, `quad j = 1, 2, cdots, n_i`, `quad i = 1, 2, cdots, r-1`. 于是 `bb 0 = sum_(i=1)^r sum_(j=1)^(n_i) k_(i j) bm alpha_(i j)` `- sum_(i=1)^(r-1) sum_(j=1)^(n_i) k_(i j) bm alpha_(i j)` `= sum_(j=1)^(n_r) k_(r j) bm alpha_(r j)`. 再由 `bm alpha_(r 1), cdots, bm alpha_(r,n_r)` 线性无关知 `k_(r 1) = k_(r 2) = cdots = k_(r,n_r) = 0`, 即全部 `n` 个向量线性无关.

不同特征值对应的特征向量线性无关. 再结合有: 当线性变换有 `n` 个不同特征值时, 它有对角形表示矩阵.

从几何重数看

令 `lambda` 为 `cc A in L(V)` 的一个特征根. `cc A` 关于 `lambda` 的特征子空间定义为 `lambda` 的全体特征向量张成的空间: `"Ker"(lambda bb I - cc A)` `:= {bm alpha in V | (lambda bb I - cc A) bm alpha = bb 0}` `= {bm alpha in V | cc A bm alpha = lambda bm alpha} le V`. 特征子空间的维数 `"dim Ker"(lambda bb I - cc A)` 称为 `lambda` 的几何重数.

几何重数的计算公式 由定义知, 特征子空间即齐次方程 `(lambda bb I - cc A) bm alpha = bb 0` 的解空间; 取定基底后, 即为 `(lambda bm I - bm A) bm X = bb 0` 的解空间. 因而有 `"dim Ker"(lambda bm I - bm A) = n - "rank"(lambda bm I - bm A)`.

任一特征根的几何重数 `le` 代数重数.

令 `cc A in L(V)`, `lambda` 为一特征根, 取特征子空间 `"Ker"(lambda bb I - cc A)` 的基底 `(bm epsi_1, bm epsi_2, cdots, bm epsi_r)`, 扩充为 `V` 的基底 `(bm epsi_1, bm epsi_2, cdots, bm epsi_n)`. 易知 `cc A` 在该基底下的矩阵为 `bm A = [lambda bm I_r, **; bm O,bm A_1]`. 因此 `Delta_(cc A)(x) = Delta_(bm A)(x)` `= (x - lambda)^r Delta_(bm A_1)(x)`. 所以 `lambda` 的几何重数 `= r le lambda` 的代数重数.

    矩阵可对角化的等价条件 设 `V` 为 `n` 维线性空间, `cc A in L(V)`, 下标 `lambda` 表示关于 `cc A` 的全体特征根求和, 则以下各款等价:
  1. `cc A` 有对角形表示矩阵;
  2. `V` 能分解为特征子空间之直和: `V = underset lambda O+ "Ker"(lambda bb I - cc A)`;
  3. `n = sum_lambda "dim Ker"(lambda bb I - cc A)`;
  4. `cc A` 在 `bbb P` 上有 `n` 个特征根 (含重数), 且每个特征根的几何重数等于其代数重数; (这是判定矩阵可对角化的标准做法)
  5. `cc A` 在 `bbb P` 上有 `n` 个特征根 (含重数), 且最小多项式 `m_(bm A)(x)` 无重根.
  1. `iff` 2. 设 `cc A` 有对角形表示矩阵, 则存在 `cc A` 的线性无关的特征向量组, 构成 `V` 的基底. 这些特征向量按其对应的特征根分属于不同的特征子空间, 构成各个特征子空间的基底. 这就给出了 `V` 在各个特征子空间上的直和分解.
    反之若 `V` 有上述直和分解, 则取各个特征子空间的基底, 就组成 `V` 的基底. 由于这个基底是由特征向量组成的, `cc A` 在该基底下的矩阵就是对角形.
  2. `rArr` 3. 使用维数公式.
  3. `rArr` 4. 因为几何重数 `le` 代数重数, 所以 `sum_lambda "dim Ker"(lambda bb I - cc A)` `le sum_lambda n_lambda` `le n`. 要使等号成立, 则必须每个特征根的几何重数等于代数重数, 且所有特征根的代数重数之和等于 `n`.
  4. `rArr` 5. 先看 `bm A = [1, 1; 0, 1]` 这个例子, 该矩阵具有二重特征根 `lambda_1 = lambda_2 = 1`. 其特征多项式和最小多项式都是 `(x-1)^2`. 此时, 我们发现它的特征子空间维数为 `n - "rank"(lambda bm I - bm A) = 1`, 即只能找到一个线性无关的特征向量.
    回到命题的证明. 设 `cc A` 有 `n` 个特征根 (含重数), 且各自的代数重数等于几何重数. 换言之存在 `cc A` 的特征向量 `bm v_1, cdots, bm v_n` 组成 `V` 的一个基底. 设 `lambda_1, cdots, lambda_r` 是两两不同的全部特征根, 考虑多项式 `p(x) = prod_(i=1)^r (x - lambda_i)`, 显然它整除 `m_(cc A)(x)`. 且 `p(cc A) bm v_i = 0`, `quad i = 1, cdots, n`. 上式可以把 `p(cc A)` 中与特征向量 `bm v_i` 相应的因子 `cc A - lambda_i bb I` 移动到最右边来计算. 但 `{bm v_i}` 是 `V` 的基底, 这说明 `p(cc A) = 0`, `p` 是 `cc A` 的零化多项式. 从而由最小多项式的定义知道 `p(x) = m_(cc A)(x)`.
  5. `rArr` 2. 设 `m_(cc A)(x) = prod_(i=1)^r (x - lambda_i)` 无重根. 我们寻求 `V` 的直和分解, 即对任意 `bm v in V`, 要找到 `bm v = sum_(i=1)^r bm v_i`, `quad bm v_i in "Ker"(lambda_i bb I - cc A)`. 容易知道各个特征子空间的交为 `{0}`, 所以上式是直和. 但是如何找到这个分解呢? 由 Lagrange 插值得到启发, 记 `f_i(x) = m_(cc A)(x) // (x - lambda_i)`, `i = 1, cdots, r`. 则 `gcd(f_1, cdots, f_r) = 1`, 从而存在 `g_1, cdots, g_r` 使得 `sum_(i=1)^r f_i(x) g_i(x) = 1`, 于是 `sum_(i=1)^r f_i(cc A) g_i(cc A) bm v` `= bb I bm v` `= bm v`. 这就给出 `V` 的分解, 可以验证其中 `bm v_i := f_i(cc A) g_i(cc A) bm v` `in "Ker"(lambda_i bb I - cc A)`.
    判断矩阵可对角化, 并求过渡矩阵 如前所述, 判断 `CC` 上方阵 `bm A` 可对角化的步骤为:
  1. 求 `bm A` 的全部 `n` 个特征根; 若 `n` 个特征根两两不同, 则 `bm A` 可对角化.
  2. 否则, 对于重根 `lambda`, 设它的 (代数) 重数为 `m`. 几何重数为 `n - "rank"(lambda bm I - bm A)`. 若每个重根的代数重数都等于几何重数, 则 `bm A` 可对角化, 否则不能.
  3. 若 `bm A` 可对角化, 将它的全部 `n` 个特征向量合并为 `bm P = (bm alpha_1, cdots, bm alpha_n)`, 则 `bm P^-1 bm A bm P` 为对角形, `bm P` 就是所求的过渡矩阵.
    利用相似初等变换进行矩阵对角化 这是一种投机取巧的方法, 计算量小, 但不是每次都能奏效. 所谓相似初等变换, 是指每进行一个行初等变换 (左乘初等矩阵), 就紧接着进行一个相反的列初等变换 (右乘初等矩阵的逆), 具体为:
  1. `i` 行乘以非零常数 `k`, 然后 `i` 列乘以 `k^-1`;
  2. `i, j` 两行互换, 然后 `i, j` 两列互换;
  3. `i` 行的 `k` 倍加到 `j` 行, 然后`j` 列的 `-k` 倍加到 `i` 列.
  4. 如果矩阵经一系列相似初等变换后化为对角形, 自然说明它可对角化; 且过渡矩阵可由所施的初等变换求得: 通常在矩阵旁并置一个单位阵来记录这些变换. 请看下例.

将 `[3, 4; 5, 2]` 对角化并求过渡矩阵.

`[3, 4, 1, 0; 5, 2, 0, 1]` `underset([2-1(1)]) overset([1+2(1)]) rarr` `[7, 4, 1, 0; 0, -2, -1, 1]` `underset([1+2(4/9)]) overset([2-1(4/9)]) rarr` `[7, 0, 5/9, 4/9; 0, -2, -1, 1]`. 于是 `[3, 4; 5, 2] = bm Q^-1 [7, ; , -2] bm Q`, 其中 `bm Q = [5/9, 4/9; -1, 1]`. 这里求得的 `bm Q` 是前一种方法求得的过渡矩阵 `bm P` 的逆.

任意复方阵 `bm A` 相似于一个上三角矩阵, 它的主对角线元素是 `bm A` 的各个特征值.

对 `bm A` 的阶数 `n` 作归纳. `n = 1` 时显然成立. 假设命题对 `n-1` 阶复方阵成立, 考虑 `n` 阶方阵 `bm A`, 设 `lambda_1`, `bm X_1` 分别是 `bm A` 的特征值和对应的特征向量. 把 `X_1` 扩充为 `CC^n` 的一组基 `bm X_1, cdots, bm X_n`. 令 `bm T = (bm X_1, cdots, bm X_n)`, 则 `bm T` 为 `n` 阶可逆方阵. 由 `bm A bm X_1 = lambda_1 bm X_1` 知 `bm (A T) = bm A(bm X_1, cdots, bm X_n)` `= (lambda_1 bm X_1, bm A bm X_2, cdots, bm A bm X_n)`. `bm (A T)` 的第一列与 `bm T` 的第一列只相差常数倍, 因此 `bm T^-1 bm (A T)` 的第一列与 `bm T^-1 bm T = bm I` 的第一列也只相差常数倍, 即 `bm T^-1 bm (A T) = [lambda_1, ast; , bm A_1]`. 由归纳假设, `bm A_1` 相似于上三角阵, 因此上式也相似于上三角阵. 此命题对复方阵有效, 是因为复方阵的特征值也为复数.

实对称矩阵的特征值分解

实对称矩阵不同特征值的特征向量相互正交.

设 `lambda_1 != lambda_2` 是实对称矩阵 `bm A` 的两个不同特征值, `bm x_1, bm x_2` 是相应的特征向量, 则 `lambda_1 (bm x_1, bm x_2)` `= (bm A bm x_1, bm x_2)` `==^(bm A 对称) (bm x_1, bm A bm x_2)` `= lambda_2 (bm x_1, bm x_2)`. 但 `lambda_1 != lambda_2`, 所以 `(bm x_1, bm x_2) = 0`.

实对称矩阵的特征值都是实数, 且相应的特征向量可以取为实的.

  1. 设 `lambda` 是实对称矩阵 `bm A` 的特征值, `bm x` 是相应的特征向量, 则 `bm A bm x = lambda bm x`. 上式两边取复共轭得 `bm A bar bm x = bar lambda bar bm x`, 假如 `lambda` 不是实数, `lambda != bar lambda`, 由上一个引理知 `(bm x, bar bm x) = 0`, 即 `sum x_i bar x_i = sum |x_i|^2 = 0`. 这推出 `bm x = bb 0`, 与 `bm x` 是一个特征向量矛盾. 因此 `lambda` 是一个实数.
  2. 设 `lambda` 是 `bm A` 的一个实特征值, 在 `RR` 上解线性方程组 `(lambda bm I - bm A) bm x = 0` 即可得到实的特征向量.

实对称矩阵可以正交对角化 任意实对称矩阵 `bm A` 正交相似于如下矩阵: `bm(T^T A T) = "diag"(lambda_1, cdots, lambda_n)`, 其中 `bm T` 为正交矩阵, 即 `bm T^T = bm T^-1`. `lambda_1, cdots, lambda_n` 是 `bm A` 的 `n` 个特征值, 这些特征值都是实数.
由于 `bm T` 是正交矩阵, 所以上式既是 `bm A` 的合同对角化, 也是它的相似对角化.

对矩阵的阶数 `n` 作归纳. `n=1` 时命题显然成立, 现在设 `n-1` 时命题成立, 则对于 `n` 阶对称矩阵 `bm A`:
设 `lambda_1 in RR` 是 `bm A` 的一个特征值, `bm x_1 in RR^n` 是相应的特征向量, 且 `|bm x_1| = 1`. 将它扩充为 `RR^n` 中的标准正交基 `bm x_1, cdots, bm x_n`, 从而得到正交矩阵 `bm T_n = (bm x_1, cdots, bm x_n)`. 注意到 `bm A` 为对称矩阵, 计算知 `bm(T_n^T A T_n) = [lambda_1, 0; 0, bm A_(n-1)]`. 其中 `bm A_(n-1)` 是 `n-1` 阶实对称矩阵. 由归纳假设, 存在 `n-1` 阶正交矩阵 `bm T_(n-1)` 使得 `bm T_(n-1)^T bm A_(n-1) bm T_(n-1)` 为对角形. 现在取 `bm T = bm T_n [1, 0; 0, bm T_(n-1)]`, 则 `bm T` 是 `n` 阶正交矩阵, 使得 `bm(T^T A T)` 为对角形.

    实对称矩阵的正交对角化
  1. 设 `bm A` 为实对称矩阵, 我们先求它的 `n` 个实特征值 `lambda_1, cdots, lambda_n`;
  2. 接下来, 我们寻找一组正交的特征向量 `bm T = (bm v_1, cdots, bm v_n)`. 若特征值 `lambda_1, cdots, lambda_n` 两两不同, 则由实对称矩阵的性质, 它们对应的特征向量已经是正交的. 若有一个特征值 `lambda` 的重数为 `r gt 1`, 因为实对称矩阵可对角化, 几何重数 = 代数重数, 所以相应的特征子空间也是 `r` 维的. 通过求解线性方程组 `(lambda bm I - bm A)bm X = bb 0`, 可以得到特征子空间的基底, 再 Schmidt 正交化即可.
  3. 将上一步得到的正交特征向量单位化 (除以模长), 仍记为 `bm T = (bm v_1, cdots, bm v_n)`. 由矩阵的特征值分解定理知道 `bm A = bm(T Lambda T)^-1`, `quad bm Lambda = "diag"(lambda_1, cdots, lambda_n)`.

一般实矩阵的奇异值分解

相关阅读:QR 分解、满秩分解

特征值分解在实际应用中受到限制, 这是由于只有方阵才有特征值, 且只有它的特征向量线性无关时才有特征值分解. 奇异值分解是特征值分解的推广, 它适用于任意 `m xx n` 的实矩阵.

实矩阵 `bm A_(m xx n)` 有奇异值分解 (singular value decomposition, SVD): `bm A = bm U_(m xx m) bm D_(m xx n) bm V_(n xx n)^(-1)`. 其中 `bm U, bm V` 为正交矩阵, `bm D` 的主对角线以外全为零 (因而是对角矩阵的推广).
`bm D` 的主对角元称为 `bm A` 的奇异值. `bm (U, V)` 的列向量分别称为左奇异向量右奇异向量.

  1. 事实上, 考虑实对称矩阵 `bm A_1 = bm (A A)^T` 和 `bm A_2 = bm A^T bm A`, 设它们的特征值分解为 `bm A_1 = bm U bm D_1 bm U^(-1)`, `quad bm A_2 = bm V bm D_2 bm V^(-1)`, 因而要使等式 `bm A = bm (U D V)^(-1)` 成立, 只需找到一个矩阵 `bm D` 使 `bm D_1 = bm D bm D^T`, `quad bm D_2 = bm D^T bm D`.
  2. 知道, `bm A_1, bm A_2` 的特征值中除零特征值外完全相同, 因此不妨设 `bm D_1 = "diag"(d_1, cdots, d_r, overbrace(0, cdots, 0)^(m-r))`,
    `bm D_2 = "diag"(d_1, cdots, d_r, overbrace(0, cdots, 0)^(n-r))`.
    由于 `bm A_1, bm A_2` 半正定, 其特征值都为非负. 可以取 `bm D_(m xx n) = "diag"(sqrt d_1, cdots, sqrt d_r, 0, cdots, 0)`, 就使 成立.
    Moore-Penrose 伪逆 [来自 深度学习 花书] 假设 `bm A` 是可逆矩阵, 我们可以在方程 `bm (A x) = bm y` 两边左乘 `bm A^-1`, 得到解 `bm x = bm A^-1 bm y`. 下面将这一方法推广到一般的 `m xx n` 实矩阵. `bm A` 的伪逆定义为 `bm A^+ = lim_(alpha to 0^+) (bm A^T bm A + alpha bm I)^-1 bm A^T`. 一个更实用的公式是 `bm A^+ = bm V bm D^+ bm U^T`, 其中 `bm A = bm(U D V)^T` 是 `bm A` 的奇异值分解, 对角矩阵 `bm D` 的伪逆 `bm D^+` 是其非零元素取倒数后再转置得到的.
  1. `bm A` 的列数多于行数时, 方程欠定, `bm x = bm A^+ bm y` 是方程所有可行解中欧氏距离 `|bm x|` 最小的一个.
  2. `bm A` 的行数多于列数时, 方程超定, 可能无解. 这时 `bm x = bm A^+ bm y` 能使欧氏距离 `|bm A bm x - bm y|` 最小.
  1. `bm A^T bm A` 半正定, 特征值非负. 因此对于 `alpha gt 0`, `bm A^T bm A + alpha bm I` 的特征值全为正, 是正定矩阵.
  2. `bm A bm A^+` 是对角形矩阵, 且对角元素不是 0 就是 1.
# sympy
A.singular_value_decomposition() # 奇异值分解
A.pinv() # Moore-Penrose 伪逆

不变子空间

设 `cc A in L(V)`, `W le V`. 如果满足 `W` 在 `cc A` 下的像 `cc A(W) sube W`, 则称子空间 `W` 对线性变换 `cc A` 封闭, 或 `W` 是 `V` 关于 `cc A` 的不变子空间. 此概念是特征子空间的推广: 一维的不变子空间就是特征子空间.

  1. 零空间 `{bb 0}` 和全空间 `V` 是平凡的不变子空间, 因为它们对于任意 `V` 上的线性变换都是不变的.
  2. 特征子空间 `"Ker"(lambda bb I - cc A)` 是 `cc A` 的不变子空间. 一般地, 对任意多项式 `f`, `"Ker"f(cc A)` 是 `cc A` 的不变子空间.
  3. 若 `cc A, cc B` 可交换, 则 `cc A` 的特征子空间是 `cc B` 的不变子空间, 反之亦然.
  1. 显然.
  2. 若 `f(cc A)bm alpha = bb 0`, 则 `f(cc A)cc A bm alpha = cc A f(cc A) bm alpha = bb 0`, 所以 `cc A bm alpha in "Ker"f(cc A)`, 即 `"Ker"f(cc A)` 不变.
  3. 只需验证对于方程 `cc A bm x = lambda bm x` 的任意解 `bm x`, `cc B bm x` 仍是方程的解: `cc (A B) bm x` `= cc (B A) bm x` `= cc B (lambda bm x)` `= lambda cc B bm x`.

令 `(bm epsi_1, cdots, bm epsi_n)` 为线性空间 `V` 的一个基, `cc A in L(V)` 在该基底下的矩阵为 `[bm A_(r xx r),bm B; bm C,bm D]`, 其中 `1 le r le n-1`. 则子空间 `"span"[bm epsi_1, cdots, bm epsi_r]` 在 `cc A` 下不变当且仅当 `bm C = bm O`; `"span"[bm epsi_(r+1), cdots, bm epsi_n]` 在 `cc A` 下不变当且仅当 `bm B = bm O`.

只证第一个结论. `W := "span"[bm epsi_1, bm epsi_2, cdots, bm epsi_r]` 在 `cc A` 下不变当且仅当 `cc A bm epsi_1, cc A bm epsi_2, cdots, cc A bm epsi_r in W`, 这当且仅当 `cc A bm epsi_1, cc A bm epsi_2, cdots, cc A bm epsi_r` 可以由 `bm epsi_1, bm epsi_2, cdots, bm epsi_r` 线性表示, 从而当且仅当 `bm C = bm O`.

`cc A in L(V)` 有分块对角形矩阵表示 `"diag"(bm A_1, cdots, bm A_r)` 当且仅当 `V` 可以写为 `cc A` 的不变子空间的直和分解 `V = O+_(i=1)^r V_i`. 其中 `bm A_i` 为 `"dim"V_i` 阶方阵, `i = 1, 2, cdots, r`. 特别当每个不变子空间都为一维时, `cc A` 有对角形矩阵表示.

两个矩阵同时对角化

[来自群友 千帆过尽 勿忘初心] `bm A = [1, 1, -1; 0, 1, 0; 0, -1, 2]`, `bm B = [1, -2, 2; 4, -5, 4; 4, -4, 3]`. 求可逆矩阵 `bm P` 将 `bm A`, `bm B` 同时对角化, 即 `bm P^-1 bm (A P)`, `bm P^-1 bm (B P)` 都为对角形矩阵.

我们寻找两个矩阵的共同特征向量. 运用 sympy.Matrix 类的 eigenvects() 方法可以求得两个矩阵的特征向量分别为 `lambda_1 = lambda_2 = 1`, `lambda_3 = 2`,
`v_1 = (1, 0, 0)`, `v_2 = (0, 1, 1)`, `v_3 = (-1, 0, 1)`,
`mu_1 = mu_2 = -1`, `mu_3 = 1`,
`w_1 = (1, 1, 0)`, `w_2 = (-1, 0, 1)`, `w_3 = (1, 2, 2)`.
其中 `v_3 = w_2` 已经是一对共同特征向量. 构造 `v_1 + 2 v_2 = (1, 2, 2) = w_3`,
`w_1 + w_2 = (0, 1,1 ) = v_2`.
于是 `bm P = [1, 0, -1; 2, 1, 0; 2, 1, 1]` 就满足 `bm P^-1 bm (A P) = "diag"(1, 1, 2)`,
`bm P^-1 bm (B P) = "diag"(1, -1, -1)`.

    [群友 ζ(me)=0、中国女同] 设 `bm A, bm B` 均为 `n` 阶矩阵, `bm A` 有 `n` 个互不相同的特征值, 且 `bm(A B)` 可交换. 证明:
  1. `bm B` 可对角化;
  2. 存在多项式 `f(x)` 使 `bm B = f(bm A)`.
  1. 首先 `bm A` 可对角化, 设 `bm A = bm (P D P)^-1`. 于是 `bm (P D P)^-1 bm B = bm (B P D P)^-1`. 左乘 `bm P^-1`, 右乘 `bm P`, `bm (D P)^-1 bm (B P) = bm P^-1 bm (B P D)`. 因为 `bm D` 是对角元两两不同的对角矩阵, 和它可交换的只能是对角矩阵, 所以 `bm P^-1 bm (B P)` 为对角矩阵.
  2. 由 1. 知 `bm A, bm B` 两矩阵可被同时对角化, 设 `bm A = bm P bm D_1 bm P^-1`, `bm B = bm P bm D_2 bm P^-1`. 又记 `bm D_1, bm D_2` 的对角元分别为 `lambda_1, cdots, lambda_n` 和 `mu_1, cdots, mu_n`, 解方程组 `[ 1, lambda_1, cdots, lambda_1^(n-1); 1, lambda_2, cdots, lambda_2^(n-1); vdots, vdots, , vdots; 1, lambda_n, cdots, lambda_n^(n-1) ][a_0; a_1; vdots; a_(n-1)] = [mu_1; vdots; mu_n]`, 则 `f(x) = sum_(i=0)^(n-1) a_i x^i` 满足 `bm D_2 = f(bm D_1)`, 于是 `bm B = f(bm A)`.

[群友 ζ(me)=0] 1. 的另一证明. 由交换性知道 `bm A` 的特征子空间是 `bm B` 的不变子空间. 由于 `bm A` 可对角化, 其每个特征值对应一个 1 维的特征子空间. 即空间 `V` 可以写为 `bm B` 的不变子空间的直和分解, 且每个不变子空间都是 1 维. 由 知 `bm B` 也可对角化.

两个实对称矩阵可以同时正交对角化, 当且仅当它们的乘法可交换.

    `rArr` 显然, 因为对角矩阵是可交换的. 下证 `lArr`.
  1. 沿用前题的思路, 设 `bm (A B)` 可交换, 则 `bm A` 的特征子空间 `"Ker"(lambda bm I - bm A)` 是 `bm B` 的不变子空间. 设 `bm P` 是正交矩阵, `bm P^-1 bm (A P)` 是对角形, 则 `bm P` 的列向量是 `bm A` 的特征向量. 由 知 `bm C = bm P^-1 bm (B P)` 是分块对角形. 由于 `bm P` 正交从而对称, 这些分块也都是实对称矩阵.
  2. 现在对 `bm C` 的每个分块进行正交对角化, 得到对角矩阵 `bm Q^-1 bm (C Q)`. 其中 `bm Q` 是分块对角形, 每个小块都是正交矩阵, 因此 `bm Q` 也正交.
  3. 将每个小块 `bm Q_i` 作用于矩阵 `bm P^-1 bm (A P)` 的相应分块 `lambda_i bm I`, 有 `bm Q_i^-1 lambda_i bm I bm Q_i = lambda_i bm I`. 因此该矩阵在 `bm Q` 的作用下不变. 我们同时得到两个矩阵的正交对角化: `bm Q^-1 bm P^-1 bm (A P Q)`,
    `bm Q^-1 bm P^-1 bm (B P Q)`.

根子空间

线性变换 `cc A in L(V)` 关于特征值 `lambda` 的根子空间是指 `R_lambda := uuu_(k ge 1) "Ker"(cc A - lambda bb I)^k` `= { bm v in V | EE k in ZZ^+, (cc A - lambda bb I)^k bm v = 0 }`. 换言之, 根子空间包含所有在 `cc A - lambda bb I` 的高次幂作用下被映射为零的向量.