`lambda` 矩阵
是指元素是 `lambda` 的一元多项式的矩阵, 也可以看作是矩阵环上的一元多项式. 如
`[lambda + 1, 2; 3, lambda^2 + 4] in RR[lambda]^(2 xx 2)`
`= lambda^2 [0, 0; 0, 1] + lambda [1, 0; 0, 0] + [1, 2; 3, 4] in RR^(2 xx 2) [lambda]`.
Smith 标准形
-
`k` 阶子式
是指在 `n` 阶行列式中删去 `n-k` 行 `n-k` 列所得的 `k` 阶行列式. 有 `(n;k)^2` 种取法.
-
`k` 阶主子式
和 `k` 阶子式类似, 但删去的行号与列号必须相同. 有 `(n;k)` 种取法.
-
`k` 阶顺序主子式
在 `n` 阶行列式中取前 `k` 行前 `k` 列所得的 `k` 阶行列式. 只有一种取法.
Smith 标准形 即对角形 `lambda` 矩阵
`"diag"(f_1(lambda), cdots, f_n(lambda))`,
且前一个对角线元素 `f_i(lambda)` 整除后一个元素 `f_(i+1)(lambda)`.
比如
`"diag"(1, lambda - 1, (lambda-1)(lambda-2))`.
-
不变因子
`d_i(lambda)` 是将 `lambda` 矩阵化为 Smith 标准形后, 对角线上的全体非零元素.
-
行列式因子
`D_i(lambda)` 是 `lambda` 矩阵的全部非零 `k` 阶子式的首一的最大公因式.
规定 `D_0(lambda) = 1` 的话, 则有 `d_i = D_i // D_(i-1)`.
-
初等因子
是把不变因子中的常数 1 去掉, 其余的每个不变因子进行因式分解后得到的所有形如
`p(lambda)^a` 的因式, 其中 `p(lambda)` 为不可约多项式.
两个不变因子各自分解得到的初等因子有可能相同, 如不变因子
`1`, `color(red)(lambda)`, `color(blue)(lambda(lambda-1))`
分解得到的初等因子为
`color(red)(lambda)`, `color(blue)(lambda)`, `color(blue)(lambda-1)`.
对于一个数字矩阵 `bm A`, 它的不变因子、行列式因子、初等因子就定义为 `lambda bm I - bm A` 的相应因子.
有理标准形
数域 `bbb P` 上多项式 `f(lambda) = lambda^n + sum_(k=0)^(n-1) a_k lambda^k`
的友阵定义为
`bm A = [0, 0, cdots, 0, -a_0;
1, , , , -a_1;
, 1, , , -a_2;
, , ddots, , vdots;
, , , 1, -a_(n-1)]`.
在行列式一章我们已验证过 `det(lambda bm I - bm A) = f(lambda)`,
事实上, 进一步有 `bm A` 的不变因子, 即 `lambda bm I - bm A` 的不变因子为
`overbrace(1, cdots, 1)^(n-1), f(lambda)`.
有理标准形
是指分块对角矩阵
`bm A_(n xx n) = "diag"(bm A_1, cdots, bm A_s)`,
其中 `bm A_1, cdots, bm A_s` 分别是数域 `bbb P` 上多项式 `f_1, cdots, f_s` 的友阵,
且前一个多项式 `f_i` 整除后一个 `f_(i+1)`.
由多项式的友阵阶数等于该多项式的次数知道, `f_1, cdots, f_s` 的次数之和等于 `n`.
有理标准形 `bm A` 的不变因子为 `overbrace(1, cdots, 1)^(n-s), f_1(lambda), cdots, f_s(lambda)`,
Jordan 标准形
-
Jordan 块 是指形如
`bm J_m(lambda) = [lambda, 1, , , ;
, lambda, 1, ;
, , ddots, ddots, ;
, , , lambda, 1;
, , , , lambda]_(m xx m)`
的 `m` 阶方阵. 它具有 `m` 重特征值 `lambda`.
-
Jordan 标准形或 Jordan 形矩阵
是指一个分块对角矩阵, 其中每个对角块都是 Jordan 块. 例如
`"diag"(J_4(2), J_3(2), J_1("i"), J_3(-5))` 就是一个 Jordan 形矩阵.
考虑特征值为零的 Jordan 块 `J_m(0)`, 计算知,
`J_m(0)^2 = [0, 0, 1, , ; , 0, 0, ddots, ; , , ddots, ddots, 1; , , , 0, 0; , , , , 0]`,
`J_m(0)^(m-1) = [ , , , , 1; , , , , ; , , , , ; , , , , ; , , , , ]`,
`J_m(0)^m = 0`.
幂次每增加 1, `J_m(0)^k` 中值为 1 的斜线就向右上方移动一格, 矩阵的秩减少 1.
任意 `bm A in CC^(n xx n)` 相似于一个 Jordan 形矩阵 `bm J`,
其中每个 Jordan 块的特征值都是 `bm A` 的特征值.
不计 Jordan 块的排列顺序时, `bm J` 是唯一的,
称为 `bm A` 的 Jordan 标准形.
将方阵 `bm A` 化为 Jordan 标准形 `bm J`.
- 求出 `bm A` 的特征多项式
`Delta_A(lambda) = prod_(k=1)^s (lambda - lambda_k)^(n_k)`,
`quad sum n_k = n`.
- 对于一重的特征值 `lambda`, 它对应的 Jordan 块只能是一阶的 `[lambda]`;
对于二重的特征值, 它对应的 Jordan 块可能是两个一阶的 `[lambda, ; , lambda]` 或一个二阶的
`[lambda, 1; , lambda]`.
一般地, 对于 `m` 重特征值, 整数 `m` 的每一种分拆 `m = m_1 + cdots + m_t`
对应着一组可能的 Jordan 块 `"diag"(J_(m_1)(lambda), cdots, J_(m_t)(lambda))`.
-
这些不同的 Jordan 块互不相似.
比如两个一阶的 Jordan 块 `bm J_1 = [lambda, ; , lambda]`
和二阶 Jordan 块 `bm J_2 = [lambda, 1; , lambda]` 不相似.
这是因为如果它们相似, 则 `bm J_1 - lambda bm I` 和 `bm J_2 - lambda bm I` 也相似, 但这不可能, 因为
`"rank"(bm J_1 - lambda bm I) = 0`, 而 `"rank"(bm J_2 - lambda bm I) = 1`.
相似矩阵的秩总是相等的: 这是因为相似矩阵间相差若干初等变换, 而初等变换不改变矩阵的秩.
- 为了判断出 2. 中究竟是哪种 Jordan 块, 考虑 `(bm J - lambda bm I)^k` 的秩
`r_k = "rank"(bm J - lambda bm I)^k`
`= "rank"(bm A - lambda bm I)^k`,
`quad k = 0, 1, cdots`.
注意: 我们事先不知道 `bm J` 的形式, 因此无法直接求出 `"rank"(bm J - lambda bm I)^k`,
但可以改为求 `"rank"(bm A - lambda bm I)^k`.
-
`k = 0` 时, `(bm J - lambda bm I)^0 = bm I` 的秩为 `r_0 = n`.
`k = 1` 时, `bm J - lambda bm I` 把 `bm J` 的主对角线变为零, 于是所有 Jordan 块的秩都减少 1.
换言之, `r_0 - r_1 =` 所有 Jordan 块的数目.
`k` 从 1 变到 2 时, `bm J - lambda bm I` 中一阶 Jordan 块已经变成零, 阶数无法降低;
其他 Jordan 块的阶数都减少 1. 换言之 `r_2 - r_1 =` 阶数大于 1 的 Jordan 块的数目.
一般地
`r_(k+1) - r_k =` 阶数大于 `k` 的 Jordan 块的数目.
再作一阶差分就得到:
`(r_k - r_(k-1)) - (r_(k+1) - r_k) =` 阶数等于 `k` 的 Jordan 块数目.
-
对 `bm A` 的各个不同的特征值重复上述操作.
得知了各阶 Jordan 块的数目后, Jordan 标准形就完全确定了.
from sympy import Matrix
m = Matrix([[...]])
p, d = m.jordan_form()
simplify(p**-1*m*p - d) # zero matrix