当前位置:   article > 正文

线性代数|机器学习-P15矩阵A的低秩变换下的逆矩阵

线性代数|机器学习-P15矩阵A的低秩变换下的逆矩阵

1. 单位矩阵的秩1变换

1.1 功能说明

假设我们有一个单位矩阵I,列向量u,v那么当我们对单位向量I减去秩为1的矩阵后,其逆等于多少?
M = I − u v T , M − 1 = I + u v T 1 − v T u

M=IuvT,M1=I+uvT1vTu
M=IuvT,M1=I+1vTuuvT

  • 我们发现,对于单位矩阵进行秩为1的扰动 u v T uv^T uvT,其逆也是进行秩为1的扰动 u v T 1 − v T u \frac{uv^T}{1-v^Tu} 1vTuuvT,这个公式的好处在于,当我们知道对I的秩为1的扰动,就能通过公式直接知道其逆的扰动,真神奇!

1.2 证明

M = I − u v T ⇒ M − 1 = I + u v T 1 − v T u

M=IuvTM1=I+uvT1vTu
M=IuvTM1=I+1vTuuvT

  • 定义矩阵E表示如下:
    E = [ I u v T 1 ] , D e t [ E ] = 1 − v T u (3) E=
    [IuvT1]
    ,Det[E]=1-v^Tu\tag{3}
    E= IvTu1 ,Det[E]=1vTu(3)

    我们想求 E − 1 E^{-1} E1,可以通过增广矩阵,进行行变换得到,
  • 第一种方法是:将第一行乘以 v T v^T vT后加到第二行中.
    [ I 0 − v T 1 ] E = [ I u 0 D ] (4)
    [I0vT1]
    E=
    [Iu0D]
    \tag{4}
    IvT01 E= I0uD (4)

    E − 1 = [ I u 0 D ] − 1 [ I 0 − v T 1 ] = [ I + u D − 1 v T − u D − 1 − D − 1 v T D − 1 ] (5) E^{-1}=
    [Iu0D]
    ^{-1}
    [I0vT1]
    =
    [I+uD1vTuD1D1vTD1]
    \tag{5}
    E1= I0uD 1 IvT01 = I+uD1vTD1vTuD1D1 (5)
  • 第二种方法是:将第二行乘以 u u u后加到第一行中.
    [ I − u 0 1 ] E = [ I − u v T 0 v T 1 ] (6)
    [Iu01]
    E=
    [IuvT0vT1]
    \tag{6}
    I0u1 E= IuvTvT01 (6)

    E − 1 = [ I − u v T 0 v T 1 ] − 1 [ I − u 0 1 ] = [ M − 1 − M − 1 u − v T M − 1 1 + v T M − 1 u ] (7) E^{-1}=
    [IuvT0vT1]
    ^{-1}
    [Iu01]
    =
    [M1M1uvTM11+vTM1u]
    \tag{7}
    E1= IuvTvT01 1 I0u1 = M1vTM1M1u1+vTM1u (7)
  • 由公式4,6 可得,两个 E − 1 E^{-1} E1相等, M = I − u v T M=I-uv^T M=IuvT
    [ I + u D − 1 v T − u D − 1 − D − 1 v T D − 1 ] = [ M − 1 − M − 1 u − v T M − 1 1 + v T M − 1 u ] (8)
    [I+uD1vTuD1D1vTD1]
    =
    [M1M1uvTM11+vTM1u]
    \tag{8}
    I+uD1vTD1vTuD1D1 = M1vTM1M1u1+vTM1u (8)
  • 由第一个行,第一列可得如下
    M − 1 = I + u D − 1 v T = I + u v T 1 − v T u (9) M^{-1}=I+uD^{-1}v^T=I+\frac{uv^T}{1-v^Tu}\tag{9} M1=I+uD1vT=I+1vTuuvT(9)
  • 结论:
    M = I − u v T ⇒ M − 1 = I + u v T 1 − v T u (10) M=I-uv^T\Rightarrow M^{-1}=I+\frac{uv^T}{1-v^Tu}\tag{10} M=IuvTM1=I+1vTuuvT(10)

2. 单位矩阵 I n I_n In的秩k变换

  • 定义 M 表示如下:
    M = I − U V T → M − 1 = I n + U ( I k − V T U ) − 1 V T
    M=IUVTM1=In+U(IkVTU)1VT
    M=IUVTM1=In+U(IkVTU)1VT
  • 同理构造矩阵E
    E = [ I n U V T I k ] , d e t ( E ) = d e t ( I n − U V T )
    E=[InUVTIk],det(E)=det(InUVT)
    E= InVTUIk ,det(E)=det(InUVT)

3. 一般矩阵A的秩k变换

  • Sherman-Morrison-Woodbury formula
  • 定义 M 表示如下:
    M = A − U V T
    M=AUVT
    M=AUVT

    - M − 1 = A − 1 + A − 1 U ( I − V T A − 1 U ) − 1 V T A − 1
    M1=A1+A1U(IVTA1U)1VTA1
    M1=A1+A1U(IVTA1U)1VTA1
  • 同理构造矩阵E
    E = [ A U V T I ] , d e t ( E ) = d e t ( A − U V T )
    E=[AUVTI],det(E)=det(AUVT)
    E= AVTUI ,det(E)=det(AUVT)

4. 公式用途

4.1 求解方程

( I k − U V T ) x = b → x = [ I n + U ( I k − V T U ) − 1 V T ] b

(IkUVT)x=bx=[In+U(IkVTU)1VT]b
(IkUVT)x=bx=[In+U(IkVTU)1VT]b

4.2 卡曼滤波

当我们有一个已知的方程解 A x = b Ax=b Ax=b,最小二乘的结果如下:
A T A x ^ = A T b

ATAx^=ATb
ATAx^=ATb

  • 突然我们需要新增一行数据 v T v^T vT,那么矩阵变成如下:
    [ A T v ] [ A v T ] x ^ = [ A T v ] [ b b m + 1 ]
    [ATv][AvT]x^=[ATv][bbm+1]
    [ATv] AvT x^=[ATv] bbm+1
  • 整理可得如下:
    [ A T A + v v T ] x ^ = A T b + v b m + 1
    [ATA+vvT]x^=ATb+vbm+1
    [ATA+vvT]x^=ATb+vbm+1
  • 我们发现原来的矩阵为 A T A A^TA ATA,后来加了一个秩1的矩阵 v v T vv^T vvT,那么在假设原来 A T A A^TA ATA可逆的情况下,可以直接通过公式求得:
    M = A T A − v v T
    M=ATAvvT
    M=ATAvvT

    M − 1 = ( A T A ) − 1 + ( A T A ) − 1 v ( I + v T ( A T A ) − 1 v ) − 1 v T ( A T A ) − 1
    M1=(ATA)1+(ATA)1v(I+vT(ATA)1v)1vT(ATA)1
    M1=(ATA)1+(ATA)1v(I+vT(ATA)1v)1vT(ATA)1

    这样就可以在原来的结果基础上直接得到新解。
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/黑客灵魂/article/detail/754147
推荐阅读
相关标签
  

闽ICP备14008679号