当前位置: 首页 > news >正文

【R语言】主成分分析与因子分析

一、主成分分析

主成分分析(Principal Component Analysis, PCA)是一种常用的无监督数据降维技术,广泛应用于统计学、数据科学和机器学习等领域。它通过正交化线性变换将(高维)原始数据投影到一个新的坐标系(低维空间),同时保留数据的主要变异信息,使得新坐标系中的第一个坐标轴(主成分1)上的方差最大,第二个坐标轴(主成分2)上的方差次大,并且各个坐标轴之间相互正交(即不相关)。PCA 的目标是通过保留数据的主要变异方向来减少数据的维度,同时尽可能少地丢失信息。

psych扩展包能提供很丰富和有用的函数,它的输出结果也更接近商业统计分析软件,如SAS和SPSS等,所使用的函数为principal()函数

principal()函数

# 准备数据(以 iris 数据集为例)
head(iris)
# 去除标签列,只保留数值列
iris_data <- iris[, 1:4]
head(iris_data)

 principal()函数的nfactors用来指定各种主成分,iris_data里面有4种变量,所以指定为4。

library(psych)
pcal_iris <- principal(iris_data, nfactors=4)
pcal_iris

从上面的结果可知,前三个成分(RC1+RC3+RC2)的累计解释比例(Cumulative Proportion)为99%,前两个成分(RC1+RC3)的累计解释比例(Cumulative Proportion)为72%,所以选择这两个或三个主要成分是合适的。 

pcal_iris1 <- principal(iris_data, nfactors=3)
pcal_iris1

从上面结果可知,当nfactors为3时,累计比例能近似达到100%,说明用三个主成分代替原有变量的信息是足够的。 

二、因子分析

因子分析(Factor Analysis)是一种降维技术,它用于研究变量之间的内在关系,试图通过少数几个“潜在变量”(或称“因子”)来解释多个观测变量之间的相关性,其核心思想是降维结构探测。这些潜在变量是不可直接观测的,但可以通过它们对观测变量的影响来推断。因子分析在心理学、社会学、市场研究、生物学等多个领域都有广泛应用。

根据是否已知潜在结构,可以将因子分析分为探索性因子分析(Exploratory Factor Analysis,EFA)和验证性因子分析(Confirmatory Factor Analysis,CFA)。

1、注意事项

在进行因子分析,需要注意以下两个方面。

保证有足够的样本量。一般认为样本量小于50时,不适合做因子分析;样本量至少在100以上;样本量达到1000时,效果会比较好。而且,样本量的选择还受原始变量数量的影响,一般样本量至少是原始变量数量的5倍以上,10倍更好。

原始变量之间应该要有足够的相关性。如果所有或者大部分原始变量是相互独立或者相关系数都小于0.3,则不能从中提取公共因子,即数据不适合进行因子分析。

原始变量之间的相关性可以使用KMO(Kaiser-Meyer-Oklin)检验Bartlett球形检验

因子分析可以使用psych扩展包中的fa()函数

fa(r, nfactors, n.obs, rotate, scores, fm)

  1. r:相关系数矩阵或者原始数据矩阵;
  2. nfactor:因子数,默认为1;
  3. n.obs:观测数,当r为相关系数矩阵时需手动输入;
  4. rotate:设定因子旋转的方法,默认为promax(斜交旋转);还有 varimax(正交旋转)旋转有助于更好地解释因子结构。
  5. scores:是否计算因子得分,默认为FALSE,且要求r为原始数据矩阵;
  6. fm:因子提取方法,默认为minres,一般选择ml(最大似然法)。

相关文章:

  • 【vue】nodejs版本管理利器:nvm
  • MySQL 之INDEX 索引(Index Index of MySQL)
  • 请求转发和响应重定向
  • 深入剖析模型推理:原理、技术与挑战
  • QT--对话框的切换
  • Vue 中 MVVM、MVC 和 MVP 模式的区别
  • Linux中挂载是什么意思?
  • 网络安全要学python 网络安全要学爬虫吗
  • 【数据分析】1 认识数据分析
  • 【Java进阶篇】——第11篇:Java 8 新特性及使用
  • Go入门之map
  • 在unity中实现隐藏窗口,显示系统托盘图标,右键菜单退出功能
  • springMvc
  • Ai模型-PyTorch和Tensorflow的区别
  • 【2024 CSDN博客之星】大学四年,我如何在CSDN实现学业与事业的“双逆袭”?
  • 09Elasticsearch02
  • SQL数据处理函数全解析
  • 使用Python脚本下载王者**游戏英雄皮肤原画图片(含源码)
  • JavaScript表单介绍
  • 发现一个挺好的项目,可以在springboot项目中快速接入DeepSeek API,有需要的可以尝试一下
  • 蓝佛安:中方将采取更加积极有为的宏观政策,有信心实现2025年的5%左右增长目标
  • 竞彩湃|巴萨客场淘汰国际米兰,巴黎双杀阿森纳
  • 马上评|从一个细节看今年五一档电影
  • 新闻1+1丨多地政府食堂开放 “舌尖上的服务”,反映出怎样的理念转变?
  • 福建两名厅级干部履新,张文胜已任省委省直机关工委副书记
  • 准85后青海海北州副州长、州公安局局长李贤荣挂职临沂市副市长