【统计学习】主成分分析PCA(Princple Component Analysis)从原理到实现


#encoding: UTF-8
'''
Created on 2016��12��14��
@author: YYH
'''
import numpy as np
from array import array
# 自己实现参考
# http://blog.csdn.net/u012162613/article/details/42177327
# 传入的数据格式: array
# 每一行代表一个样本
# 每一列代表一个唯度的信息
#数据中心化,使得各个维度的信息均为0
def meanshift(dataArr):
mean = np.mean(dataArr,axis=0)#对每一列求均值
newData = dataArr-mean
return newData,mean
def zeroData(dataArr,mean):
newData = dataArr-mean
return newData
class PCA:
def __init__(self, n_components=1,percentage=0.99):
self.dstDim = n_components
self.reservePercentage = percentage
def __del__(self):
pass
def fit(self,dataArr):
zeroMeanData,meanVal = meanshift(dataArr)
self.meanVal = meanVal#保存数据中心
# 求协方差矩阵,rowvar = 0:一行代表一个样本
cov = np.cov(zeroMeanData,rowvar=0)
#求特征值和特征向量,特征向量是按列放的,即一列代表一个特征向量
eigVals,eigVector =np.linalg.eig(cov)
eigValsIndice = np.argsort(eigVals)#从小到大排列
n_eigValsIndice = eigValsIndice[-1:-(self.dstDim+1):-1] #最大的n个特征的下标
n_eigVect = eigVector[:,n_eigValsIndice]#最大的n个特征值对应的特征向量
n_eigVect = np.matrix(n_eigVect)
self.n_eigVect = n_eigVect #保存特征向量
def fit_transform(self,dataArr):
zeroMeanData,meanVal = meanshift(dataArr)
self.meanVal = meanVal#保存数据中心
# 求协方差矩阵,rowvar = 0:一行代表一个样本
cov = np.cov(zeroMeanData,rowvar=0)
#求特征值和特征向量,特征向量是按列放的,即一列代表一个特征向量
eigVals,eigVector =np.linalg.eig(cov)
eigValsIndice = np.argsort(eigVals)#从小到大排列
n_eigValsIndice = eigValsIndice[-1:-(self.dstDim+1):-1] #最大的n个特征的下标
n_eigVect = eigVector[:,n_eigValsIndice]#最大的n个特征值对应的特征向量
zeroMeanData = np.matrix(zeroMeanData)
n_eigVect = np.matrix(n_eigVect)
self.n_eigVect = n_eigVect #保存特征向量
lowDData = zeroMeanData*n_eigVect #低维特征空间的数据
# reConData = (lowDData*n_eigVect.T)+meanVal #重构数据
return lowDData
def transform(self,dataArr):
zeroMeanData = zeroData(dataArr,self.meanVal)
zeroMeanData = np.matrix(zeroMeanData)
lowDData = zeroMeanData*self.n_eigVect #低维特征空间的数据
# reConData = (lowDData*n_eigVect.T)+meanVal #重构数据
return lowDData
【代码验证】
在做手写数字识别时,我分别使用了sklearn的PCA,和自己整理的PCA,达到的准确度都到了96%左右。
在PCA降维后的数据来看,可能在特征向量上方向不同,导致部分列跟sklearn的符号相反
时间上,可能自己整理实现的PC A现在耗时短点,毕竟目前是比较简单的PC A


【统计学习】主成分分析PCA(Princple Component Analysis)从原理到实现的更多相关文章
- R: 主成分分析 ~ PCA(Principal Component Analysis)
本文摘自:http://www.cnblogs.com/longzhongren/p/4300593.html 以表感谢. 综述: 主成分分析 因子分析 典型相关分析,三种方法的共同点主要是用来对数据 ...
- 用scikit-learn学习主成分分析(PCA)
在主成分分析(PCA)原理总结中,我们对主成分分析(以下简称PCA)的原理做了总结,下面我们就总结下如何使用scikit-learn工具来进行PCA降维. 1. scikit-learn PCA类介绍 ...
- 解释一下核主成分分析(Kernel Principal Component Analysis, KPCA)的公式推导过程(转载)
KPCA,中文名称”核主成分分析“,是对PCA算法的非线性扩展,言外之意,PCA是线性的,其对于非线性数据往往显得无能为力,例如,不同人之间的人脸图像,肯定存在非线性关系,自己做的基于ORL数据集的实 ...
- 核主成分分析(Kernel Principal Component Analysis, KPCA)的公式推导过程
KPCA,中文名称”核主成分分析“,是对PCA算法的非线性扩展,言外之意,PCA是线性的,其对于非线性数据往往显得无能为力,例如,不同人之间的人脸图像,肯定存在非线性关系,自己做的基于ORL数据集的实 ...
- PCA(Principal Component Analysis)笔记
PCA是机器学习中recognition中的传统方法,今天下午遇到了,梳理记一下 提出背景: 二维空间里,2个相近的样本,有更大概率具有相同的属性,但是在高维空间里,由于样本在高维空间里,呈现越来越稀 ...
- 主成分分析(principal components analysis, PCA)——无监督学习
降维的两种方式: (1)特征选择(feature selection),通过变量选择来缩减维数. (2)特征提取(feature extraction),通过线性或非线性变换(投影)来生成缩减集(复合 ...
- 《principal component analysis based cataract grading and classification》学习笔记
Abstract A cataract is lens opacification caused by protein denaturation which leads to a decrease i ...
- 机器学习 —— 基础整理(四)特征提取之线性方法:主成分分析PCA、独立成分分析ICA、线性判别分析LDA
本文简单整理了以下内容: (一)维数灾难 (二)特征提取--线性方法 1. 主成分分析PCA 2. 独立成分分析ICA 3. 线性判别分析LDA (一)维数灾难(Curse of dimensiona ...
- 【机器学习】--主成分分析PCA降维从初识到应用
一.前述 主成分分析(Principal Component Analysis,PCA), 是一种统计方法.通过正交变换将一组可能存在相关性的变量转换为一组线性不相关的变量,转换后的这组变量叫主成分. ...
随机推荐
- 页面解耦—— 统跳协议和Rewrite引擎
原文: http://pingguohe.net/2015/11/24/Navigator-and-Rewrite.html 解耦神器 —— 统跳协议和Rewrite引擎 Nov 24, 2015 • ...
- excel 2010 学习笔记一 Vlookup 函数的使用
有这么一句话说的好:在商用场合里,能证明你会基本的EXCEL操作技巧的两个检查标准就是会不会用VLOOKUP函数以及数据透视表功能,那么今天就来总结一下VLOOKUP的一些简单实用的功能. 1.VLO ...
- C#多线程--信号量(Semaphore)
百度百科:Semaphore,是负责协调各个线程, 以保证它们能够正确.合理的使用公共资源.也是操作系统中用于控制进程同步互斥的量. Semaphore常用的方法有两个WaitOne()和Releas ...
- soft-margin SVM
1. soft-margin SVM的形式 其中ξn表示每个点允许的犯错程度(偏离margin有多远),但是犯错是有代价的,也就是目标函数里面要最小化的.c控制对犯错的容忍程度. 2. 推导soft ...
- linux终端实现代理
ubuntu 14.04安装Shadowsocks-Qt5 sudo add-apt-repository ppa:hzwhuang/ss-qt5 sudo apt-get update sudo a ...
- 得到 window.open 新页面中的数据
1.htm 页面 单击按 '钮后' 调用window.open方法,开启新窗口 2.htm 想实现---------------------- 在2.htm页面单击按钮 将相应的数据返回到 1. ...
- 打印IP 来源
<% String userAgent = request.getHeader("User-Agent"); if (userAgent != null && ...
- C/C++: C++变量和基本类型
1. 如何选择类型的准则 当明确知晓数值不可能为负的时候,应该选择无符号类型. 使用int执行整数运算的时候,在实际应用中,short常常显得太小而long一般和int有一样的尺寸,如果数值超过了in ...
- doT.js学习
doT.js特点是快,小,无依赖其他插件.但是一般和jquery一起使用 官网:http://olado.github.io 使用方法:{{= }} for interpolation{{ }} fo ...
- VC 鼠标滚轮事件控制绘图的问题
问题描述: 在MFC中绘制数据曲线,通过鼠标滚轮来进行放大缩小操作.在使用滚轮事件时,发现如果数据量较大,会出现卡顿. 解决方案: 鼠标滚轮事件会进行重复绘图,考虑在鼠标滚轮结束之后再重绘: 在鼠标滚 ...