首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >R中的SVD计算

R中的SVD计算
EN

Stack Overflow用户
提问于 2014-02-24 12:04:50
回答 2查看 222关注 0票数 1

如何在R中有效地使用奇异值分解(SVD)获得实际矩阵,原因A=svd$u %*% svd$d %*% t(svd$v)这不是获得矩阵A的有效方法

EN

回答 2

Stack Overflow用户

发布于 2014-02-24 14:40:40

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

代码语言:javascript
复制
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
票数 2
EN

Stack Overflow用户

发布于 2014-02-24 15:05:18

通过@MYaseen208改进答案

代码语言:javascript
复制
(s$u) %*% (t(s$v)*s$d)

这样就少了一个矩阵乘法运算(这是一个O(n^3)的运算)。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/21978677

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档