0

在我正在构建的一个闪亮的应用程序中,我只想显示主函数(r 包 psych 的)输出的解释方差和模型拟合度量。我调查了输出的结构,但不幸的是(也许有点奇怪)我找不到这些值的确切位置。有谁知道如何从输出中获取这些值?

4

1 回答 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 回答