3

我最近读到了如何使用 Choleski 分解计算 QR 分解的 R 矩阵。关系是:

R = Choleski 分解(A^TA)

例子:

> A=matrix(c(1,2,3,2,3,5,1,3,2), nrow=3)
> A
     [,1] [,2] [,3]
[1,]    1    2    1
[2,]    2    3    3
[3,]    3    5    2

> AtA = t(A)%*%A
> AtA
     [,1] [,2] [,3]
[1,]   14   23   13
[2,]   23   38   21
[3,]   13   21   14

现在计算 QR 和 Choleski 分解:

> chol(AtA)
         [,1]     [,2]       [,3]
[1,] 3.741657 6.147009  3.4743961
[2,] 0.000000 0.462910 -0.7715167
[3,] 0.000000 0.000000  1.1547005

> qr_A = qr(A)
> qr.R(qr_A)
          [,1]      [,2]       [,3]
[1,] -3.741657 -6.147009 -3.4743961
[2,]  0.000000  0.462910 -0.7715167
[3,]  0.000000  0.000000 -1.1547005

正如所观察到的,从 Choleski 和 QR 分解计算的 R 矩阵的值并不相同。第一行和第三行chol(AtA)被否定 wrt qr.R(qr_A)。这是为什么?我假设的关系不正确吗?

4

1 回答 1

5

矩阵的 QR 分解不是唯一的!有一个 R=chol(AtA) 的 QR 分解,但也有其他的,qr不一定要给出那个。在你的例子中

qr.Q(qr_A)%*%qr.R(qr_A) 

(qr.Q(qr_A)%*%diag(c(-1,1,-1)))%*%chol(AtA)

都是 A 的有效 QR 分解。

于 2013-10-23T11:25:12.590 回答