2014-02-24 76 views
1

我如何R中使用奇異值分解(SVD) 有效地得到實際的矩陣, 原因A=svd$u %*% svd$d %*% t(svd$v)這不是一個有效的方式來獲得矩陣ASVD計算中的R

+0

[Package'svd'](http://cran.r-project.org/web/packages/svd/svd.pdf)也許? –

回答

2

嘗試svd(A)$u%*%diag(svd(A)$d)%*%t(svd(A)$v)

set.seed(12345) 
A <- matrix(data=runif(n=9, min=1, max=9), nrow=3) 
A 
     [,1]  [,2]  [,3] 
[1,] 6.767231 8.088997 3.600763 
[2,] 8.006186 4.651848 5.073795 
[3,] 7.087859 2.330974 6.821642 

s <- svd(A) 
D <- diag(s$d) 
s$u %*% D %*% t(s$v) 
     [,1]  [,2]  [,3] 
[1,] 6.767231 8.088997 3.600763 
[2,] 8.006186 4.651848 5.073795 
[3,] 7.087859 2.330974 6.821642 
1

通過@ MYaseen208

(s$u) %*% (t(s$v)*s$d) 

這具有少一個矩陣乘法(這是一個爲O​​(n^3)操作)在改進了答案。