一、因子分析的意义
在研究实际问题时往往希望尽可能多地收集相关变量,以期望能对问题有比较全面、完整的把握和认识。例如,对高等学校科研状况的评价研究,可能会搜集诸如投入科研活动的人数、立项课题数、项目经费、经费支出、结项课题数、发表论文数、发表专著数、获得奖励数等多项指标;再例如,学生综合评价研究中,可能会搜集诸如基础课成绩、专业基础课成绩、专业课成绩、体育等各类课程的成绩以及累计获得各项奖学金的次数等。虽然收集这些数据需要投入许多精力,虽然它们能够较为全面精确地描述事物,但在实际数据建模时,这些变量未必能真正发挥预期的作用,“投入”和“产出”并非呈合理的正比,反而会给统计分析带来很多问题,可以表现在:
计算量的问题
由于收集的变量较多,如果这些变量都参与数据建模,无疑会增加分析过程中的计算工作量。虽然,现在的计算技术已得到了迅猛发展,但高维变量和海量数据仍是不容忽视的。
变量间的相关性问题
收集到的诸多变量之间通常都会存在或多或少的相关性。例如,高校科研状况评价中的立项课题数与项目经费、经费支出等之间会存在较高的相关性;学生综合评价研究中的专业基础课成绩与专业课成绩、获奖学金次数等之间也会存在较高的相关性。而变量之间信息的高度重叠和高度相关会给统计方法的应用带来许多障碍。例如,多元线性回归分析中,如果众多解释变量之间存在较强的相关性,即存在高度的多重共线性,那么会给回归方程的参数估计带来许多麻烦,致使回归方程参数不准确甚至模型不可用等。类似的问题还有很多。
为了解决这些问题,最简单和最直接的解决方案是削减变量的个数,但这必然又会导致信息丢失和信息不完整等问题的产生。为此,人们希望探索一种更为有效的解决方法,它既能大大减少参与数据建模的变量个数,同时也不会造成信息的大量丢失。因子分析正式这样一种能够有效降低变量维数,并已得到广泛应用的分析方法。
因子分析的概念起源于20世纪初Karl Pearson和Charles Spearmen等人关于智力
测验的统计分析。目前,因子分析已成功应用于心理学、医学、气象、地址、经济学等领域,并因此促进了理论的不断丰富和完善。
因子分析以最少的信息丢失为前提,将众多的原有变量综合成较少几个综合指标,名为因子。通常,因子有以下几个特点:
因子个数远远少于原有变量的个数
原有变量综合成少数几个因子之后,因子将可以替代原有变量参与数据建模,这将大大减少分析过程中的计算工作量。
因子能够反映原有变量的绝大部分信息
因子并不是原有变量的简单取舍,而是原有变量重组后的结果,因此不会造成原有变量信息的大量丢失,并能够代表原有变量的绝大部分信息。
因子之间的线性关系并不显著
由原有变量重组出来的因子之间的线性关系较弱,因子参与数据建模能够有效地解决变量多重共线性等给分析应用带来的诸多问题。
因子具有命名解释性
通常,因子分析产生的因子能够通过各种方式最终获得命名解释性。因子的命名解释性有助于对因子分析结果的解释评价,对因子的进一步应用有重要意义。例如,对高校科研情况的因子分析中,如果能够得到两个因子,其中一个因子是对科研人力投入、经费投入、立项项目数等变量的综合,而另一个是对结项项目数、发表论文数、获奖成果数等变量的综合,那么,该因子分析就是较为理想的。因为这两个因子均有命名可解释性,其中一个反映了科研投入方面的情况,可命名为科研投入因子,另一个反映了科研产出方面的情况,可命名为科研产出因子。
总之,因子分析是研究如何以最少的信息丢失将众多原有变量浓缩成少数几个因子,如何使因子具有一定的命名解释性的多元统计分析方法。
二、因子分析的基本概念
1、因子分析模型
因子分析模型中,假定每个原始变量由两部分组成:共同因子(common factors)
和唯一因子(unique factors)。共同因子是各个原始变量所共有的因子,解释变量之间的相关关系。唯一因子顾名思义是每个原始变量所特有的因子,表示该变量不能被共同因子解释的部分。原始变量与因子分析时抽出的共同因子的相关关系用因子负荷(factor loadings)表示。
因子分析最常用的理论模式如下:
Zj?aj1F1?aj2F2?aj3F3?????ajmFm?Uj(j=1,2,3…,n,n为原始变量总数)
可以用矩阵的形式表示为Z?AF?U。其中F称为因子,由于它们出现在每个原始变量的线性表达式中(原始变量可以用Xj表示,这里模型中实际上是以F线性表示各个原始变量的标准化分数Zj),因此又称为公共因子。因子可理解为高维空间中互相垂直的m个坐标轴,A称为因子载荷矩阵,aji(j?1,2,3...n,i?1,2,3...m)称为因子载荷,是第j个原始变量在第i个因子上的负荷。如果把变量Zj看成m维因子空间中的一个向量,则
aji表示Zj在坐标轴Fi上的投影,相当于多元线性回归模型中的标准化回归系数;U称为
特殊因子,表示了原有变量不能被因子解释的部分,其均值为0,相当于多元线性回归模型中的残差。
其中,
(1)Zj为第j个变量的标准化分数; (2)Fi(i=1,2,…,m)为共同因素; (3)m为所有变量共同因素的数目; (4)Uj为变量Zj的唯一因素; (5)aji为因素负荷量。
2、因子分析数学模型中的几个相关概念 因子载荷(因素负荷量factor loadings)
所谓的因子载荷就是因素结构中,原始变量与因素分析时抽取出共同因素的相关。可以证明,在因子不相关的前提下,因子载荷aji是变量Zj和因子Fi的相关系数,反映了
变量Zj与因子Fi的相关程度。因子载荷aji值小于等于1,绝对值越接近1,表明因子Fi与变量Zj的相关性越强。同时,因子载荷aji也反映了因子Fi对解释变量Zj的重要作用和程度。因子载荷作为因子分析模型中的重要统计量,表明了原始变量和共同因子之间的相关关系。因素分析的理想情况,在于个别因素负荷量aji不是很大就是很小,这样每个变量才能与较少的共同因素产生密切关联,如果想要以最少的共同因素数来解释变量间的关系程度,则Uj彼此间或与共同因素间就不能有关联存在。一般说来,负荷量为或更大被认为有意义。所以,当要判断一个因子的意义时,需要查看哪些变量的负荷达到了或以上。
变量共同度(共同性,Communality)
变量共同度也就是变量方差,就是指每个原始变量在每个共同因子的负荷量的平方和,也就是指原始变量方差中由共同因子所决定的比率。变量的方差由共同因子和唯一因子组成。共同性表明了原始变量方差中能被共同因子解释的部分,共同性越大,变量能被因子说明的程度越高,即因子可解释该变量的方差越多。共同性的意义在于说明如果用共同因子替代原始变量后,原始变量的信息被保留的程度。因子分析通过简化相关矩阵,提取可解释相关的少数因子。一个因子解释的是相关矩阵中的方差,而解释方差的大小称为因子的特征值。一个因子的特征值等于所有变量在该因子上的负荷值的平方总和。变量Zj的共同度h的数学定义为:h??aji,该式表明变量Zj的共同度是因子
222i?1m载荷矩阵A中第j行元素的平方和。由于变量Zj的方差可以表示成h2?u2?1,因此变量Zj的方差可由两个部分解释:第一部分为共同度h2,是全部因子对变量Zj方差解释说明的比例,体现了因子全体对变量Zj的解释贡献程度。变量共同度h2越接近1,说明因子全体解释说明了变量Zj的较大部分方差,如果用因子全体刻画变量Zj,则变量Zj的信息丢失较少;第二部分为特殊因子U的平方,反应了变量Zj方差中不能由因子全体解释说明的比例,u2越小则说明变量Zj的信息丢失越少。
总之,变量d共同度刻画了因子全体对变量Zj信息解释的程度,是评价变量Zj信息
丢失程度的重要指标。如果大多数原有变量的变量共同度均较高(如高于),则说明提取的因子能够反映原有变量的大部分信息(80%以上)信息,仅有较少的信息丢失,因子分析的效果较好。因子,变量共同度是衡量因子分析效果的重要依据。
因子的方差贡献(特征值eigenvalue)
因子的方差贡献(特征值)的数学定义为:Si??aji,该式表明,因子Fi的方差
2j?1n2贡献是因子载荷矩阵A中第i列元素的平方和。因子Fi的方差贡献反映了因子Fi对原有变量总方差的解释能力。该值越高,说明相应因子的重要性越高。因此,因子的方差贡献和方差贡献率是衡量因子重要性的关键指标。
为了便于说明,以三个变量抽取两个共同因素为例,三个变量的线性组合分别为:
Z1?a11F1?a12F2?U1 Z2?a21F1?a22F2?U2 Z3?a31F1?a32F2?U3
转换成因素矩阵如下:
F1 (共同因素一) 变量 F2 (共同因素二) 共同性 (h) 2唯一因素 (d) 22X1 X2 X3 特征值 2a11 a21 a31 a12 a22 a32 2a11?a12 a21?a22 2221?h1 1?h2 22a31?a32 2221?h3 2a11?a21?a31 a11?a21?a31 32222a11?a21?a31 a11?a21?a31 322222 解释量 所谓共同性,就是每个变量在每个共同因素之负荷量的平方总和(一横列中所有因素负荷量的平方和),也就是个别变量可以被共同因素解释的变异量百分比,这个值是个别变量与共同因素间多元相关的平方。从共同性的大小可以判断这个原始变量与共同因