R:由下对角线生成对称矩阵

  • 本文关键字:对称 对角线 matrix
  • 更新时间 :
  • 英文 :


我有一个矩阵的下三角形,我想把它转换成dissim矩阵,因此它需要是对称的。

print(rdf)
         X0        X1        X2        X3 X4
0 0.0000000        NA        NA        NA NA
1 0.5340909 0.0000000        NA        NA NA
2 0.5340909 0.0000000 0.0000000        NA NA
3 0.3200000 0.5227273 0.5227273 0.0000000 NA
4 0.6263736 0.4945055 0.4945055 0.5384615  0
library(gdata)
upperTriangle(rdf) <- lowerTriangle(rdf)
isSymmetric(rdf)
       X0        X1        X2        X3        X4
0 0.0000000 0.5340909 0.5340909 0.6263736 0.4945055
1 0.5340909 0.0000000 0.3200000 0.0000000 0.5227273
2 0.5340909 0.0000000 0.0000000 0.5227273 0.4945055
3 0.3200000 0.5227273 0.5227273 0.0000000 0.5384615
4 0.6263736 0.4945055 0.4945055 0.5384615 0.0000000
[1] FALSE

怎么回事?注意,我不需要使用gdata

你需要确保你复制的元素的顺序是正确的:

m <- matrix(NA,4,4)
m[lower.tri(m,diag=TRUE)] <- 1:10
     [,1] [,2] [,3] [,4]
[1,]    1   NA   NA   NA
[2,]    2    5   NA   NA
[3,]    3    6    8   NA
[4,]    4    7    9   10
makeSymm <- function(m) {
   m[upper.tri(m)] <- t(m)[upper.tri(m)]
   return(m)
}
makeSymm(m)

或者您可以使用内置的

Matrix::forceSymmetric(m,uplo="L")

最新更新