矩阵求逆的几种方式(以二阶为例)
矩阵求逆的方法有多种,以下是常用的几种方式总结:
1. 行列式公式法
这是最常见的方法,适用于 2 × 2 2 \times 2 2×2矩阵。
对于矩阵:
Φ = [ a b c d ] , \Phi = \begin{bmatrix} a & b \\ c & d \end{bmatrix}, Φ=[acbd],
其逆矩阵为:
Φ − 1 = 1 det ( Φ ) [ d − b − c a ] , \Phi^{-1} = \frac{1}{\text{det}(\Phi)} \begin{bmatrix} d & -b \\ -c & a \end{bmatrix}, Φ−1=det(Φ)1[d−c−ba],
前提是行列式 det ( Φ ) = a d − b c ≠ 0 \text{det}(\Phi) = ad - bc \neq 0 det(Φ)=ad−bc=0。
2. 伴随矩阵法
适用于任意 n × n n \times n n×n矩阵,特别是在符号化计算中常用。
步骤:
- 计算矩阵的代数余子式,构造伴随矩阵 adj ( Φ ) \text{adj}(\Phi) adj(Φ)。
- 使用公式:
Φ − 1 = 1 det ( Φ ) ⋅ adj ( Φ ) . \Phi^{-1} = \frac{1}{\text{det}(\Phi)} \cdot \text{adj}(\Phi). Φ−1=det(Φ)1⋅adj(Φ).
对于 2 × 2 2 \times 2 2×2矩阵:
adj ( Φ ) = [ d − b − c a ] . \text{adj}(\Phi) = \begin{bmatrix} d & -b \\ -c & a \end{bmatrix}. adj(Φ)=[d−c−ba].
以下是** 2 × 2 2 \times 2 2×2矩阵伴随矩阵**的推导过程:
2.1. 伴随矩阵定义
给定矩阵:
Φ = [ a b c d ] , \Phi = \begin{bmatrix} a & b \\ c & d \end{bmatrix}, Φ=[acbd],
伴随矩阵 adj ( Φ ) \text{adj}(\Phi) adj(Φ)是 Φ \Phi Φ的代数余子式矩阵的转置。
2.2. 求代数余子式
代数余子式 A i j A_{ij} Aij定义为:
A i j = ( − 1 ) i + j ⋅ M i j , A_{ij} = (-1)^{i+j} \cdot M_{ij}, Aij=(−1)i+j⋅Mij,
其中 M i j M_{ij} Mij是去掉矩阵 Φ \Phi Φ第 i i i行、第 j j j列后得到的余矩阵的行列式。
对于 2 × 2 2 \times 2 2×2矩阵 Φ \Phi Φ,每个代数余子式计算如下:
-
计算 A 11 A_{11} A11:
A 11 = ( − 1 ) 1 + 1 ⋅ det [ d ] = 1 ⋅ d = d . A_{11} = (-1)^{1+1} \cdot \text{det}\begin{bmatrix} d \end{bmatrix} = 1 \cdot d = d. A11=(−1)1+1⋅det[d]=1⋅d=d. -
计算 A 12 A_{12} A12:
A 12 = ( − 1 ) 1 + 2 ⋅ det [ c ] = − 1 ⋅ c = − c . A_{12} = (-1)^{1+2} \cdot \text{det}\begin{bmatrix} c \end{bmatrix} = -1 \cdot c = -c. A12=(−1)1+2⋅det[c]=−1⋅c=−c. -
计算 A 21 A_{21} A21:
A 21 = ( − 1 ) 2 + 1 ⋅ det [ b ] = − 1 ⋅ b = − b . A_{21} = (-1)^{2+1} \cdot \text{det}\begin{bmatrix} b \end{bmatrix} = -1 \cdot b = -b. A21=(−1)2+1⋅det[b]=−1⋅b=−b. -
计算 A 22 A_{22} A22:
A 22 = ( − 1 ) 2 + 2 ⋅ det [ a ] = 1 ⋅ a = a . A_{22} = (-1)^{2+2} \cdot \text{det}\begin{bmatrix} a \end{bmatrix} = 1 \cdot a = a. A22=(−1)2+2⋅det[a]=1⋅a=a.
2.3. 构造代数余子式矩阵
将上述代数余子式按原矩阵 Φ \Phi Φ的顺序排列,得到代数余子式矩阵:
代数余子式矩阵 = [ A 11 A 12 A 21 A 22 ] = [ d − c − b a ] . \text{代数余子式矩阵} = \begin{bmatrix} A_{11} & A_{12} \\ A_{21} & A_{22} \end{bmatrix} =\begin{bmatrix} d & -c \\ -b & a \end{bmatrix}. 代数余子式矩阵=[A11A21A12A22]=[d−b−ca].
2.4. 求伴随矩阵
伴随矩阵是代数余子式矩阵的转置:
adj ( Φ ) = [ d − c − b a ] T = [ d − b − c a ] . \text{adj}(\Phi) = \begin{bmatrix} d & -c \\ -b & a\end{bmatrix}^T= \begin{bmatrix} d & -b \\ -c & a \end{bmatrix}. adj(Φ)=[d−b−ca]T=[d−c−ba].
因此对于 2 × 2 2 \times 2 2×2矩阵:
Φ = [ a b c d ] , \Phi = \begin{bmatrix} a & b \\ c & d \end{bmatrix}, Φ=[acbd],
其伴随矩阵为:
adj ( Φ ) = [ d − b − c a ] . \text{adj}(\Phi) = \begin{bmatrix} d & -b \\ -c & a \end{bmatrix}. adj(Φ)=[d−c−ba].
3. 初等行变换法(高斯-约旦消元法)
通过将矩阵扩展为一个分块矩阵:
[ Φ ∣ I ] , [\Phi | I], [Φ∣I],
然后对左边矩阵执行初等行变换,直到其变成单位矩阵 I I I,右侧的矩阵就是逆矩阵 Φ − 1 \Phi^{-1} Φ−1。
以下是利用高斯-约旦消元法求矩阵逆矩阵的详细步骤(以 2 × 2 2 \times 2 2×2矩阵为例):
3.1. 问题描述
给定一个 2 × 2 2 \times 2 2×2矩阵:
Φ = [ a b c d ] , \Phi = \begin{bmatrix} a & b \\ c & d \end{bmatrix}, Φ=[acbd],
目标是通过初等行变换计算其逆矩阵 Φ − 1 \Phi^{-1} Φ−1。
3.2. 扩展增广矩阵
将 Φ \Phi Φ扩展为增广矩阵:
[ Φ ∣ I ] = [ a b 1 0 c d 0 1 ] . [\Phi | I] = \begin{bmatrix} a & b & 1 & 0 \\ c & d & 0 & 1 \end{bmatrix}. [Φ∣I]=[acbd1001].
目标是通过行变换将左侧矩阵变成单位矩阵 I I I,右侧变成逆矩阵 Φ − 1 \Phi^{-1} Φ−1。
3.3 高斯-约旦消元法步骤
步骤 1:将 [ 1 , 1 ] [1,1] [1,1]位置元素变为1(主元化)
通过行变换使 a a a变为1。若 a ≠ 0 a \neq 0 a=0,直接将第1行除以 a a a:
R 1 → R 1 a , R_1 \to \frac{R_1}{a}, R1→aR1,
增广矩阵变为:
[ 1 b a 1 a 0 c d 0 1 ] . \begin{bmatrix} 1 & \frac{b}{a} & \frac{1}{a} & 0 \\ c & d & 0 & 1 \end{bmatrix}. [1cabda1001].
步骤 2:消去第2行的第1列元素
将第2行的第1列元素 c c c消为0:
R 2 → R 2 − c ⋅ R 1 , R_2 \to R_2 - c \cdot R_1, R2→R2−c⋅R1,
增广矩阵变为:
[ 1 b a 1 a 0 0 d − b c a − c a 1 ] . \begin{bmatrix} 1 & \frac{b}{a} & \frac{1}{a} & 0 \\ 0 & d - \frac{bc}{a} & -\frac{c}{a} & 1 \end{bmatrix}. [10abd−abca1−ac01].
步骤 3:将 [ 2 , 2 ] [2,2] [2,2]位置元素变为1(主元化)
通过行变换使 d − b c a d - \frac{bc}{a} d−abc变为1。若 d − b c a ≠ 0 d - \frac{bc}{a} \neq 0 d−abc=0,将第2行除以该值:
R 2 → R 2 d − b c a , R_2 \to \frac{R_2}{d - \frac{bc}{a}}, R2→d−abcR2,
增广矩阵变为:
[ 1 b a 1 a 0 0 1 − c a ( d − b c a ) 1 d − b c a ] . \begin{bmatrix} 1 & \frac{b}{a} & \frac{1}{a} & 0 \\ 0 & 1 & \frac{-c}{a(d - \frac{bc}{a})} & \frac{1}{d - \frac{bc}{a}} \end{bmatrix}. [10ab1a1a(d−abc)−c0d−abc1].
步骤 4:消去第1行的第2列元素
将第1行的第2列元素 b a \frac{b}{a} ab消为0:
R 1 → R 1 − b a ⋅ R 2 , R_1 \to R_1 - \frac{b}{a} \cdot R_2, R1→R1−ab⋅R2,
增广矩阵变为:
[ 1 0 d det ( Φ ) − b det ( Φ ) 0 1 − c det ( Φ ) a det ( Φ ) ] , \begin{bmatrix} 1 & 0 & \frac{d}{\text{det}(\Phi)} & \frac{-b}{\text{det}(\Phi)} \\ 0 & 1 & \frac{-c}{\text{det}(\Phi)} & \frac{a}{\text{det}(\Phi)} \end{bmatrix}, [1001det(Φ)ddet(Φ)−cdet(Φ)−bdet(Φ)a],
其中 det ( Φ ) = a d − b c \text{det}(\Phi) = ad - bc det(Φ)=ad−bc。
最终,左侧已变成单位矩阵 I I I,右侧即为逆矩阵 Φ − 1 \Phi^{-1} Φ−1:
Φ − 1 = 1 det ( Φ ) [ d − b − c a ] , \Phi^{-1} = \frac{1}{\text{det}(\Phi)} \begin{bmatrix} d & -b \\ -c & a \end{bmatrix}, Φ−1=det(Φ)1[d−c−ba],
前提是 det ( Φ ) ≠ 0 \text{det}(\Phi) \neq 0 det(Φ)=0。
4. 数值计算法(如LU分解法)
对于数值计算,通过矩阵分解技术(如LU分解)来求解逆矩阵:
- 将矩阵分解为 Φ = L U \Phi = LU Φ=LU的形式;
- 分别解两个三角方程,最终获得逆矩阵。
此方法更适合大规模矩阵的计算,但对于 2 × 2 2 \times 2 2×2矩阵意义有限。
以下是利用LU分解法求逆矩阵的详细步骤:
4.1. 问题描述
给定一个 2 × 2 2 \times 2 2×2矩阵:
Φ = [ a b c d ] \Phi = \begin{bmatrix} a & b \\ c & d \end{bmatrix} Φ=[acbd]
目标是通过LU分解计算其逆矩阵 Φ − 1 \Phi^{-1} Φ−1。
4.2. LU分解概念
LU分解将矩阵 Φ \Phi Φ分解为下列形式:
Φ = L U , \Phi = LU, Φ=LU,
其中:
- L L L为下三角矩阵,主对角线元素为1;
- U U U为上三角矩阵。
对于 2 × 2 2 \times 2 2×2矩阵,分解过程如下:
L = [ 1 0 l 21 1 ] , U = [ u 11 u 12 0 u 22 ] . L = \begin{bmatrix} 1 & 0 \\ l_{21} & 1 \end{bmatrix}, \quad U = \begin{bmatrix} u_{11} & u_{12} \\ 0 & u_{22} \end{bmatrix}. L=[1l2101],U=[u110u12u22].
4.3. LU分解步骤
步骤 1:初始化
假设 Φ = L U \Phi = LU Φ=LU,则有:
[ a b c d ] = [ 1 0 l 21 1 ] [ u 11 u 12 0 u 22 ] . \begin{bmatrix} a & b \\ c & d \end{bmatrix} = \begin{bmatrix} 1 & 0 \\ l_{21} & 1 \end{bmatrix} \begin{bmatrix} u_{11} & u_{12} \\ 0 & u_{22} \end{bmatrix}. [acbd]=[1l2101][u110u12u22].
通过矩阵乘法,得到:
[ a b c d ] = [ u 11 u 12 l 21 u 11 l 21 u 12 + u 22 ] . \begin{bmatrix} a & b \\ c & d \end{bmatrix} = \begin{bmatrix} u_{11} & u_{12} \\ l_{21} u_{11} & l_{21} u_{12} + u_{22} \end{bmatrix}. [acbd]=[u11l21u11u12l21u12+u22].
步骤 2:逐元素比较,确定 L L L和 U U U的元素
- 比较 [ 1 , 1 ] [1,1] [1,1]位置元素:
u 11 = a . u_{11} = a. u11=a. - 比较 [ 1 , 2 ] [1,2] [1,2]位置元素:
u 12 = b . u_{12} = b. u12=b. - 比较 [ 2 , 1 ] [2,1] [2,1]位置元素:
l 21 = c u 11 = c a . l_{21} = \frac{c}{u_{11}} = \frac{c}{a}. l21=u11c=ac. - 比较 [ 2 , 2 ] [2,2] [2,2]位置元素:
u 22 = d − l 21 u 12 = d − c a ⋅ b . u_{22} = d - l_{21} u_{12} = d - \frac{c}{a} \cdot b. u22=d−l21u12=d−ac⋅b.
最终得到:
L = [ 1 0 c a 1 ] , U = [ a b 0 d − b c a ] . L = \begin{bmatrix} 1 & 0 \\ \frac{c}{a} & 1 \end{bmatrix}, \quad U = \begin{bmatrix} a & b \\ 0 & d - \frac{bc}{a} \end{bmatrix}. L=[1ac01],U=[a0bd−abc].
4. 求逆矩阵 Φ − 1 \Phi^{-1} Φ−1
LU分解完成后,通过分块求逆的方式得到结果。
步骤 1:解 L Y = I LY = I LY=I(前向替代)
将 Φ − 1 \Phi^{-1} Φ−1分为两部分:
L Y = [ 1 0 c a 1 ] [ y 11 y 12 y 21 y 22 ] = [ 1 0 0 1 ] . LY = \begin{bmatrix} 1 & 0 \\ \frac{c}{a} & 1 \end{bmatrix} \begin{bmatrix} y_{11} & y_{12} \\ y_{21} & y_{22} \end{bmatrix} = \begin{bmatrix} 1 & 0 \\ 0 & 1 \end{bmatrix}. LY=[1ac01][y11y21y12y22]=[1001].
逐行解得:
- 第1行:
y 11 = 1 , y 12 = 0. y_{11} = 1, \quad y_{12} = 0. y11=1,y12=0. - 第2行:
y 21 = − c a , y 22 = 1. y_{21} = -\frac{c}{a}, \quad y_{22} = 1. y21=−ac,y22=1.
因此:
Y = [ 1 0 − c a 1 ] . Y = \begin{bmatrix} 1 & 0 \\ -\frac{c}{a} & 1 \end{bmatrix}. Y=[1−ac01].
步骤 2:解 U Z = Y UZ = Y UZ=Y(后向替代)
[ a b 0 d − b c a ] [ z 11 z 12 z 21 z 22 ] = [ 1 0 − c a 1 ] . \begin{bmatrix} a & b \\ 0 & d - \frac{bc}{a} \end{bmatrix} \begin{bmatrix} z_{11} & z_{12} \\ z_{21} & z_{22} \end{bmatrix} = \begin{bmatrix} 1 & 0 \\ -\frac{c}{a} & 1 \end{bmatrix}. [a0bd−abc][z11z21z12z22]=[1−ac01].
逐行解得:
- 第2行:
z 21 = − c a d − b c a = − c a d − b c , z 22 = 1 d − b c a = a a d − b c . z_{21} = \frac{-\frac{c}{a}}{d - \frac{bc}{a}} = \frac{-c}{ad - bc}, \quad z_{22} = \frac{1}{d - \frac{bc}{a}} = \frac{a}{ad - bc}. z21=d−abc−ac=ad−bc−c,z22=d−abc1=ad−bca. - 第1行:
z 11 = 1 − b ⋅ z 21 a = d a d − b c , z 12 = 0 − b ⋅ z 22 a = − b a d − b c . z_{11} = \frac{1 - b \cdot z_{21}}{a} = \frac{d}{ad - bc}, \quad z_{12} = \frac{0 - b \cdot z_{22}}{a} = \frac{-b}{ad - bc}. z11=a1−b⋅z21=ad−bcd,z12=a0−b⋅z22=ad−bc−b.
最终得到:
Z = [ d a d − b c − b a d − b c − c a d − b c a a d − b c ] . Z = \begin{bmatrix} \frac{d}{ad - bc} & \frac{-b}{ad - bc} \\ \frac{-c}{ad - bc} & \frac{a}{ad - bc} \end{bmatrix}. Z=[ad−bcdad−bc−cad−bc−bad−bca].
因此,逆矩阵为:
Φ − 1 = Z = 1 det ( Φ ) [ d − b − c a ] . \Phi^{-1} = Z = \frac{1}{\text{det}(\Phi)} \begin{bmatrix} d & -b \\ -c & a \end{bmatrix}. Φ−1=Z=det(Φ)1[d−c−ba].
LU分解法通过矩阵分解简化了求解逆矩阵的过程,特别是对于高维矩阵,通过分解后的前向替代和后向替代显著提高了计算效率。
5. 符号化工具或计算机软件
如使用数学软件(Matlab、NumPy)直接调用内置函数:
- NumPy:
np.linalg.inv(Phi)
- Matlab:
inv(Phi)
这类方法内部可能实现了上述的数值算法,适合工程计算。
6. 定义验证法
利用逆矩阵的定义 Φ Φ − 1 = I \Phi \Phi^{-1} = I ΦΦ−1=I,通过代数方程的形式验证或构造满足该条件的矩阵。
例如,对于简单的 2 × 2 2 \times 2 2×2矩阵,可以手动解联立方程组获得逆矩阵。
6.1. 问题描述
给定一个 2 × 2 2 \times 2 2×2矩阵:
Φ = [ a b c d ] , \Phi = \begin{bmatrix} a & b \\ c & d \end{bmatrix}, Φ=[acbd],
我们要求矩阵 Φ \Phi Φ的逆矩阵 Φ − 1 \Phi^{-1} Φ−1,并利用定义 Φ Φ − 1 = I \Phi \Phi^{-1} = I ΦΦ−1=I来求解。
我们假设 Φ − 1 \Phi^{-1} Φ−1为:
Φ − 1 = [ x y z w ] . \Phi^{-1} = \begin{bmatrix} x & y \\ z & w \end{bmatrix}. Φ−1=[xzyw].
6.2. 利用矩阵乘法公式
根据定义 Φ Φ − 1 = I \Phi \Phi^{-1} = I ΦΦ−1=I,我们可以写出方程:
[ a b c d ] [ x y z w ] = [ 1 0 0 1 ] . \begin{bmatrix} a & b \\ c & d \end{bmatrix} \begin{bmatrix} x & y \\ z & w \end{bmatrix} =\begin{bmatrix} 1 & 0 \\ 0 & 1 \end{bmatrix}. [acbd][xzyw]=[1001].
进行矩阵乘法,得到:
[ a x + b z a y + b w c x + d z c y + d w ] = [ 1 0 0 1 ] . \begin{bmatrix} ax + bz & ay + bw \\ cx + dz & cy + dw \end{bmatrix} =\begin{bmatrix} 1 & 0 \\ 0 & 1 \end{bmatrix}. [ax+bzcx+dzay+bwcy+dw]=[1001].
6.3. 通过逐元素比较构造方程
从上面的等式中,我们得到以下4个方程:
-
第一行第一列:
a x + b z = 1. ax + bz = 1. ax+bz=1. -
第一行第二列:
a y + b w = 0. ay + bw = 0. ay+bw=0. -
第二行第一列:
c x + d z = 0. cx + dz = 0. cx+dz=0. -
第二行第二列:
c y + d w = 1. cy + dw = 1. cy+dw=1.
这些方程构成了一个线性方程组,接下来我们解这个方程组。
6.4. 解联立方程组
为了得到 x , y , z , w x, y, z, w x,y,z,w的值,我们可以按照以下步骤进行解算。
步骤 1:解第3个方程
从第3个方程:
c x + d z = 0 , cx + dz = 0, cx+dz=0,
解得:
z = − c d x . z = -\frac{c}{d}x. z=−dcx.
步骤 2:代入第1个方程
将 z = − c d x z = -\frac{c}{d}x z=−dcx代入第1个方程:
a x + b ( − c d x ) = 1 , ax + b\left(-\frac{c}{d}x\right) = 1, ax+b(−dcx)=1,
得到:
a x − b c d x = 1. ax - \frac{bc}{d}x = 1. ax−dbcx=1.
提取 x x x,得到:
x ( a − b c d ) = 1. x\left(a - \frac{bc}{d}\right) = 1. x(a−dbc)=1.
因此:
x = d a d − b c . x = \frac{d}{ad - bc}. x=ad−bcd.
步骤 3:解第4个方程
从第4个方程:
c y + d w = 1 , cy + dw = 1, cy+dw=1,
解得:
w = 1 − c y d . w = \frac{1 - cy}{d}. w=d1−cy.
步骤 4:代入第2个方程
将 w = 1 − c y d w = \frac{1 - cy}{d} w=d1−cy代入第2个方程:
a y + b ( 1 − c y d ) = 0 , ay + b\left(\frac{1 - cy}{d}\right) = 0, ay+b(d1−cy)=0,
得到:
a y + b ( 1 − c y ) d = 0 , ay + \frac{b(1 - cy)}{d} = 0, ay+db(1−cy)=0,
整理后:
a y + b d − b c d y = 0. ay + \frac{b}{d} - \frac{bc}{d}y = 0. ay+db−dbcy=0.
提取 y y y,得到:
y ( a − b c d ) = − b d . y\left(a - \frac{bc}{d}\right) = -\frac{b}{d}. y(a−dbc)=−db.
因此:
y = − b a d − b c . y = \frac{-b}{ad - bc}. y=ad−bc−b.
步骤 5:解 w w w
将 y = − b a d − b c y = \frac{-b}{ad - bc} y=ad−bc−b代入 w = 1 − c y d w = \frac{1 - cy}{d} w=d1−cy:
w = 1 − c ( − b a d − b c ) d = d a d − b c . w = \frac{1 - c\left(\frac{-b}{ad - bc}\right)}{d} = \frac{d}{ad - bc}. w=d1−c(ad−bc−b)=ad−bcd.
#3## 6.5. 最终结果
通过以上步骤,我们得到了 Φ − 1 \Phi^{-1} Φ−1的各个元素:
Φ − 1 = [ d a d − b c − b a d − b c − c a d − b c a a d − b c ] . \Phi^{-1} = \begin{bmatrix} \frac{d}{ad - bc} & \frac{-b}{ad - bc} \\ \frac{-c}{ad - bc} & \frac{a}{ad - bc} \end{bmatrix}. Φ−1=[ad−bcdad−bc−cad−bc−bad−bca].
利用逆矩阵的定义 Φ Φ − 1 = I \Phi \Phi^{-1} = I ΦΦ−1=I,我们通过构造并解联立方程组的方法成功求得了 2 × 2 2 \times 2 2×2矩阵的逆矩阵。该方法虽然手动推导较为繁琐,但对于理解逆矩阵的性质和计算过程具有重要的理论意义。
7. 比较总结
方法 | 特点 | 适用场景 |
---|---|---|
行列式公式法 | 直接计算,简单明了 | 小规模矩阵 |
伴随矩阵法 | 适用于符号化求解,但计算代数余子式较繁琐 | 手动推导或符号化运算 |
初等行变换法 | 理论基础强,操作灵活 | 理论学习与推导 |
数值计算法 | 效率高,适合大矩阵 | 工程计算与编程实现 |
符号化工具或函数 | 快捷简洁,依赖工具 | 实际工程问题求解 |
定义验证法 | 基础方法,计算量较大 | 理论验证与构造 |