如何通过将每个原始值除以原始矩阵中该列的原始平方值的平方根来获得.
data(longley)
X <- as.matrix(longley[,-7])
X/sqrt(colSums(X^2))
Run Code Online (Sandbox Code Playgroud)
得出错误的结果.
试试这个:
t(t(X)/sqrt(colSums(X^2)))
Run Code Online (Sandbox Code Playgroud)
基准:
library(microbenchmark)
microbenchmark(t(t(X)/sqrt(colSums(X^2))),
apply(X, 2 , function(x) x/sqrt(sum(x^2))))
# Unit: microseconds
# expr min lq median uq max neval
# t(t(X)/sqrt(colSums(X^2))) 28.783 33.1305 34.9455 40.5640 68.147 100
# apply(X, 2, function(x) x/sqrt(sum(x^2))) 100.307 105.1940 106.9975 108.1075 193.015 100
Run Code Online (Sandbox Code Playgroud)