博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
主成分分析 SPSS、python实例分析
阅读量:6457 次
发布时间:2019-06-23

本文共 6063 字,大约阅读时间需要 20 分钟。

 

  今天,在西瓜书上看到了主成分分析法,之前建模有接触过但是理解不够深刻,今天再次和这一位老朋友聊聊。

  主成分分析(Principal Component Analysis,PCA), 是一种统计方法。通过正交变换将一组可能存在相关性的变量转换为一组线性不相关的变量,转换后的这组变量叫主成分。

  主成分分析,是考察多个变量间相关性一种多元统计方法,研究如何通过少数几个主成分来揭示多个变量间的内部结构,即从原始变量中导出少数几个主成分,使它们尽可能多地保留原始变量的信息,且彼此间互不相关.通常数学上的处理就是将原来P个指标作线性组合,作为新的综合指标。

  简单说,主成分分析的作用是降维。通过降维将原来多变量解释的问题,映射到更少指标,转换成少变量的可解释性问题。但是注意经过主成分分析后的变量与原变量不存在逻辑关系,仅仅是存在线性组合的关系。[1]

 一、算法原理:


 

输入:样本集D={x1,x2...xm};

   低维空间维数d'.

过程:

1.对所有样本进行中心化:

2.计算样本的协方差矩阵XXT

3.对协方差矩阵XXT做特征值分解;

4.取最大的d'个特征值所对应的特征向量w1,w2...wd';

输出:投影矩阵W*=(w1,w2...wd') .[2]


 

二、PCA原理

  

  

  

 

 

 

三、SPSS进行主成分分析

  由于SPSS本身就是一个用于数据分析的软件,因此操作简单无需编程,即可直观感受主成分分析带来的效果。

  先胡乱编制了一些数据:

  

  

  在SPSS里,点击分析->降维->因子,在弹出的对话框中,将需要分析的变量都送入变量栏中。根据个人需要在描述、提取、旋转、得分、选项中勾选。此处我们注意在提取勾选主成分。

  

 

点击“确定”: 

  

  

最后我们可以看到提取了两个主成分

  

 

  

观察两个主成分中的贡献率,我们会发现第一个主成分包含贡献率较高的项为数学、物理、化学、生物,实际意义即理科,第二主成分包含历史、地理,即文科。具有良好解释性。

 

四、python代码实现主成分分析

pca.py

# -*- coding: utf-8 -*-"""Created on Sun Feb 28 10:04:26 2016PCA source code@author: liudiwei"""import numpy as npimport pandas as pdimport matplotlib.pyplot as plt#计算均值,要求输入数据为numpy的矩阵格式,行表示样本数,列表示特征    def meanX(dataX):    return np.mean(dataX,axis=0)#axis=0表示按照列来求均值,如果输入list,则axis=1#计算方差,传入的是一个numpy的矩阵格式,行表示样本数,列表示特征    def variance(X):    m, n = np.shape(X)    mu = meanX(X)    muAll = np.tile(mu, (m, 1))        X1 = X - muAll    variance = 1./m * np.diag(X1.T * X1)    return variance#标准化,传入的是一个numpy的矩阵格式,行表示样本数,列表示特征    def normalize(X):    m, n = np.shape(X)    mu = meanX(X)    muAll = np.tile(mu, (m, 1))        X1 = X - muAll    X2 = np.tile(np.diag(X.T * X), (m, 1))    XNorm = X1/X2    return XNorm"""参数:	- XMat:传入的是一个numpy的矩阵格式,行表示样本数,列表示特征    	- k:表示取前k个特征值对应的特征向量返回值:	- finalData:参数一指的是返回的低维矩阵,对应于输入参数二	- reconData:参数二对应的是移动坐标轴后的矩阵"""  def pca(XMat, k):    average = meanX(XMat)     m, n = np.shape(XMat)    data_adjust = []    avgs = np.tile(average, (m, 1))    data_adjust = XMat - avgs    covX = np.cov(data_adjust.T)   #计算协方差矩阵    featValue, featVec=  np.linalg.eig(covX)  #求解协方差矩阵的特征值和特征向量    index = np.argsort(-featValue) #按照featValue进行从大到小排序    finalData = []    if k > n:        print("k must lower than feature number")        return    else:        #注意特征向量时列向量,而numpy的二维矩阵(数组)a[m][n]中,a[1]表示第1行值        selectVec = np.matrix(featVec.T[index[:k]]) #所以这里需要进行转置        finalData = data_adjust * selectVec.T         reconData = (finalData * selectVec) + average      return finalData, reconDatadef loaddata(datafile):    return np.array(pd.read_csv(datafile,sep="\t",header=-1)).astype(np.float)def plotBestFit(data1, data2):	      dataArr1 = np.array(data1)    dataArr2 = np.array(data2)        m = np.shape(dataArr1)[0]    axis_x1 = []    axis_y1 = []    axis_x2 = []    axis_y2 = []    for i in range(m):        axis_x1.append(dataArr1[i,0])        axis_y1.append(dataArr1[i,1])        axis_x2.append(dataArr2[i,0])         axis_y2.append(dataArr2[i,1])				      fig = plt.figure()    ax = fig.add_subplot(111)    ax.scatter(axis_x1, axis_y1, s=50, c='red', marker='s')    ax.scatter(axis_x2, axis_y2, s=50, c='blue')    plt.xlabel('x1'); plt.ylabel('x2');    plt.savefig("outfile.png")    plt.show()	#简单测试#数据来源:http://www.cnblogs.com/jerrylead/archive/2011/04/18/2020209.htmldef test():    X = [[2.5, 0.5, 2.2, 1.9, 3.1, 2.3, 2, 1, 1.5, 1.1],         [2.4, 0.7, 2.9, 2.2, 3.0, 2.7, 1.6, 1.1, 1.6, 0.9]]    XMat = np.matrix(X).T      k = 2    return pca(XMat, k)#根据数据集data.txtdef main():        datafile = "data.txt"    XMat = loaddata(datafile)    k = 2    return pca(XMat, k)    if __name__ == "__main__":    finalData, reconMat = main()    plotBestFit(finalData, reconMat)

 

data.txt

5.1	3.5	1.4	0.24.9	3.0	1.4	0.24.7	3.2	1.3	0.24.6	3.1	1.5	0.25.0	3.6	1.4	0.25.4	3.9	1.7	0.44.6	3.4	1.4	0.35.0	3.4	1.5	0.24.4	2.9	1.4	0.24.9	3.1	1.5	0.15.4	3.7	1.5	0.24.8	3.4	1.6	0.24.8	3.0	1.4	0.14.3	3.0	1.1	0.15.8	4.0	1.2	0.25.7	4.4	1.5	0.45.4	3.9	1.3	0.45.1	3.5	1.4	0.35.7	3.8	1.7	0.35.1	3.8	1.5	0.35.4	3.4	1.7	0.25.1	3.7	1.5	0.44.6	3.6	1.0	0.25.1	3.3	1.7	0.54.8	3.4	1.9	0.25.0	3.0	1.6	0.25.0	3.4	1.6	0.45.2	3.5	1.5	0.25.2	3.4	1.4	0.24.7	3.2	1.6	0.24.8	3.1	1.6	0.25.4	3.4	1.5	0.45.2	4.1	1.5	0.15.5	4.2	1.4	0.24.9	3.1	1.5	0.15.0	3.2	1.2	0.25.5	3.5	1.3	0.24.9	3.1	1.5	0.14.4	3.0	1.3	0.25.1	3.4	1.5	0.25.0	3.5	1.3	0.34.5	2.3	1.3	0.34.4	3.2	1.3	0.25.0	3.5	1.6	0.65.1	3.8	1.9	0.44.8	3.0	1.4	0.35.1	3.8	1.6	0.24.6	3.2	1.4	0.25.3	3.7	1.5	0.25.0	3.3	1.4	0.27.0	3.2	4.7	1.46.4	3.2	4.5	1.56.9	3.1	4.9	1.55.5	2.3	4.0	1.36.5	2.8	4.6	1.55.7	2.8	4.5	1.36.3	3.3	4.7	1.64.9	2.4	3.3	1.06.6	2.9	4.6	1.35.2	2.7	3.9	1.45.0	2.0	3.5	1.05.9	3.0	4.2	1.56.0	2.2	4.0	1.06.1	2.9	4.7	1.45.6	2.9	3.6	1.36.7	3.1	4.4	1.45.6	3.0	4.5	1.55.8	2.7	4.1	1.06.2	2.2	4.5	1.55.6	2.5	3.9	1.15.9	3.2	4.8	1.86.1	2.8	4.0	1.36.3	2.5	4.9	1.56.1	2.8	4.7	1.26.4	2.9	4.3	1.36.6	3.0	4.4	1.46.8	2.8	4.8	1.46.7	3.0	5.0	1.76.0	2.9	4.5	1.55.7	2.6	3.5	1.05.5	2.4	3.8	1.15.5	2.4	3.7	1.05.8	2.7	3.9	1.26.0	2.7	5.1	1.65.4	3.0	4.5	1.56.0	3.4	4.5	1.66.7	3.1	4.7	1.56.3	2.3	4.4	1.35.6	3.0	4.1	1.35.5	2.5	4.0	1.35.5	2.6	4.4	1.26.1	3.0	4.6	1.45.8	2.6	4.0	1.25.0	2.3	3.3	1.05.6	2.7	4.2	1.35.7	3.0	4.2	1.25.7	2.9	4.2	1.36.2	2.9	4.3	1.35.1	2.5	3.0	1.15.7	2.8	4.1	1.36.3	3.3	6.0	2.55.8	2.7	5.1	1.97.1	3.0	5.9	2.16.3	2.9	5.6	1.86.5	3.0	5.8	2.27.6	3.0	6.6	2.14.9	2.5	4.5	1.77.3	2.9	6.3	1.86.7	2.5	5.8	1.87.2	3.6	6.1	2.56.5	3.2	5.1	2.06.4	2.7	5.3	1.96.8	3.0	5.5	2.15.7	2.5	5.0	2.05.8	2.8	5.1	2.46.4	3.2	5.3	2.36.5	3.0	5.5	1.87.7	3.8	6.7	2.27.7	2.6	6.9	2.36.0	2.2	5.0	1.56.9	3.2	5.7	2.35.6	2.8	4.9	2.07.7	2.8	6.7	2.06.3	2.7	4.9	1.86.7	3.3	5.7	2.17.2	3.2	6.0	1.86.2	2.8	4.8	1.86.1	3.0	4.9	1.86.4	2.8	5.6	2.17.2	3.0	5.8	1.67.4	2.8	6.1	1.97.9	3.8	6.4	2.06.4	2.8	5.6	2.26.3	2.8	5.1	1.56.1	2.6	5.6	1.47.7	3.0	6.1	2.36.3	3.4	5.6	2.46.4	3.1	5.5	1.86.0	3.0	4.8	1.86.9	3.1	5.4	2.16.7	3.1	5.6	2.46.9	3.1	5.1	2.35.8	2.7	5.1	1.96.8	3.2	5.9	2.36.7	3.3	5.7	2.56.7	3.0	5.2	2.36.3	2.5	5.0	1.96.5	3.0	5.2	2.06.2	3.4	5.4	2.35.9	3.0	5.1	1.8

  代码运行结果:

 

参考文献:

[1] https://baike.baidu.com/item/%E4%B8%BB%E6%88%90%E5%88%86%E5%88%86%E6%9E%90/829840?fr=aladdin

[2]周志华,机器学习,清华大学出版社,2016年1月1版.

 

2019-03-09

00:05:40

转载于:https://www.cnblogs.com/lyxyhhxbk/p/10494560.html

你可能感兴趣的文章
js滚动加载到底部
查看>>
Virtualbox 虚拟机网络不通
查看>>
java概念基础笔记整理
查看>>
leetcode124二叉树最大路径和
查看>>
AngularJS笔记整理 内置指令与自定义指令
查看>>
shell与正则表达式
查看>>
第三篇:白话tornado源码之请求来了
查看>>
表示数值的字符串
查看>>
JQUERY AJAX请求
查看>>
超级账本Fabric区块链用弹珠游戏Marbles 部署
查看>>
控制圈复杂度的9种重构技术总结
查看>>
数据分析--数字找朋友
查看>>
18年selenium3+python3+unittest自动化测试教程(下)
查看>>
memcache数据库和redis数据库的区别(理论)
查看>>
我的友情链接
查看>>
MyBatis+Spring结合
查看>>
Office 365之SkyDrive Pro
查看>>
无缝滚动实现原理分析【公告栏】
查看>>
Java Web 高性能开发
查看>>
CentOS 4.4双网卡绑定,实现负载均衡
查看>>