在我正在构建的一个闪亮的应用程序中,我只想显示主函数(r 包 psych 的)输出的解释方差和模型拟合度量。我调查了输出的结构,但不幸的是(也许有点奇怪)我找不到这些值的确切位置。有谁知道如何从输出中获取这些值?
问问题
1111 次
1 回答
5
首先,如果您希望得到帮助,您应该提供一个可重复的示例,其中包括您的数据样本。这就是为什么你的问题被否决(虽然不是我)。
由第 i 个主成分引起的方差由相关矩阵的第 i 个特征值给出。由于根据定义,PC 是正交(不相关)的,因此总方差由单个方差之和 = 特征值之和给出。特征值在 中返回principal(...)$values
。因此,每台 PC 解释的总方差的比例由下式给出:
prop.table(principal(...)$values)
由于您没有提供任何数据,我将使用内置mtcars
数据集作为工作示例:
library(psych)
df <- mtcars[c("hp","mpg","disp","wt","qsec")]
pca <- principal(df)
prop.table(pca$values)
# [1] 0.73936484 0.19220335 0.03090626 0.02623083 0.01129473
因此,第一台 PC 解释了总变化的 74%,第二台 PC 解释了 19%,依此类推。这与使用 的结果完全prcomp(...)
一致,请记住principal(...)
默认情况下会缩放,而prcomp(...)
不会缩放。
pc <- prcomp(df,scale.=T)
summary(pc)
# Importance of components:
# PC1 PC2 PC3 PC4 PC5
# Standard deviation 1.9227 0.9803 0.39310 0.36215 0.23764
# Proportion of Variance 0.7394 0.1922 0.03091 0.02623 0.01129
# Cumulative Proportion 0.7394 0.9316 0.96247 0.98871 1.00000
principal(...)$fit.off
如文档中所述,参数“基于非对角线值拟合”在 中给出。
于 2014-04-29T21:01:14.920 回答