Data Science with R in 4 Weeks - Week 3 - Day1

Dimension Reduction -  PCA(Principle Component Analysis) as an example


我们经常会听到这样的说法:说明理由的时候,最好不要超过3~4个,否则别人记不住;希望消费者记住你的产品的时候,最好强调2~3个卖点,再多了,消费者记不住,也不关心。这就是降维技术在生活中最典型的应用——如果你有多个理由,多个信息,要把它们浓缩成最重要的几点,以便于别人理解和记忆。

商业中也经常遇到这样的问题,像前面提到过的欧洲国家蛋白质摄入渠道,福特汽车的主要卖点,都有超过3个以上的维度。事实上,我们发现,一旦超过了3个,消费者或听众是很难理解的。

再比如,一个班级的学生,每个人都参加文学、数学、几何、写作、历史、生物、物理、经济学、大众传媒这9门课的考试,每个人的成绩都是0~100之间的一个分值。那么,根据考试成绩,这些学生应该如何分组呢?一种方法就是按照我们前面讲过的 cluster analysis的方法,将9门考试看做9个维度,然后进行分组分析,问题是,即便我们得到了不同的分组,我们也可能解释不同分组的区别。

如果我们能将数据降维呢?比如,我们将9个维度降低成2个维度 —— Verbal 和quantitative,也就是语言能力和数理能力。按照这两个维度,我们可以重新对学生进行分组,得到的结果,会非常易于解释。

PCA(Principle Component Analysis) 就是这样一种技术。它在很多方面都有应用。

例子:

我们用R自带的一个dataset做例子,这个dataset是33名运动员 奥林匹克10项全能的比赛数据:

> library(ade4)

> data(olympic)

> attach(olympic)



做PCA分析

> pca.olympic = dudi.pca(olympic$tab,scale=F,scannf=F,nf=2)

> scatter(pca.olympic)

可以看到,最长的两个轴,一个是1500,另一个javelin throw.

但因为我们没有对数据进行标准化,所以,我们这次采用standardize data。

> pca.olympic = dudi.pca(olympic$tab,scale=T,scannf=F,nf=2)

> scatter(pca.olympic)


坐标轴选择之后(如图中粉色的新的坐标轴),我们看到第一象限的 正坐标轴主要和跑步有关,纵坐标主要和田径有关。

> s.label(pca.olympic$co, boxes=F)


现在,我们能较好的解释10项全能的维度了。主要衡量三个指标——runnnig, jumping, athletic.

按照这三个指标,我们可以重新对运动员的成绩形成cluster analysis。看那些运动员是running 能力比较强,那些事jumping能力比较强等等。

( PS: 这么解读数据是不正确的,只是直观上看上去,数据好像是这样分布的。 Dimension 1 只能表示一个指标,dimension 2 也只能表示一个指标。例如,jumping和running分布在dimension 1的两端,这说明dimension 1 可能解释的是运动员的综合能力,运动的灵活性等。此外,jumping 和running 负相关,如果跑得越快,jump的越高)


另一个例子,采用FactoMineR  package 的 dataset decathlon. 数据几乎是一样的,但是PCA的R 函数不一样。

install.packages(FactoMineR)

library(FactoMineR)

> data(decathlon)

> head(decathlon)

在第一个例子中,我们让 nf =2。但是,进行PCA分析之前,我们怎么知道应该有多少个components呢?FactoMineR 提供了一个函数,可以用来估计最佳的 dimension。

estim_ncp并不是总能给出唯一的答案。所以,使用的时候最好能够做cross reference check。

我们使用3个component的方案。


res.pca1 = PCA(decathlon[, 1:10], scale.unit = TRUE, ncp = 3, graph = TRUE)

plot(res.pca1)

我们发现,第1,2两个dimension合起来能够解释dataset里面 50%左右的信息

Variables factor map 解释各个vector之间的相关性。90度表示没有关系,0度,100%正相关,180度,100%负相关。这里,我们可以注意到, 100m, 110m hurdle和long jump是负相关的,而discus,short put和long jump几乎不相关。仔细想一下,这样的结果是有道理的:首先,铅球(shot put)和铁饼(discus)的成绩和跳远的成绩应该不相关,毕竟,一个是力量型的运动,另一个是跳跃型的运动; 其次,100m,110m 栏和跳远的成绩负相关,100m的成绩越好(数值越小),跳远的成绩越好(数值越大)。

我们旋转坐标轴,让 100m和long jump 位于dimension 1 上,让 discus 位于dim 2上。

Dataset 里面的col 11和12,提供了定量的辅助信息,在做PCA的时候,我们可以把这些信息加入到里面:

> res.pca2 = PCA(decathlon[, 1:12], scale.unit = TRUE, ncp = 3, quanti.sup = c(11:12), graph = TRUE)

我们发现,rank和points和dim 1 高度的相关。这可能说明,dim 1 解释的是(主要表明)运动员的总体表现。dim2 和shot put,discuss 正相关,这可能说明,dim 2 解释的是(主要表明)运动员的力量方面的表现。

定性的辅助信息也可以加入:

res.pca3 = PCA(decathlon, scale.unit = TRUE, ncp = 3, quanti.sup = c(11:12), quali.sup = 13, graph = TRUE)

我们也可以把参加olympic的运动员用其他颜色标注出来,重新画图

plot.PCA(res.pca3, axes = c(1, 2), choix = "ind", habillage = 13)

解读图表和数据

(1)在运动员的总体表现上(dim1), karpov是最佳的,uldal是最差的。

(2)总体上,我们发现参加olympic的运动员比参加decathlon的运动员综合表现要好(why?可能是因为竞争比较激烈,他们的训练强度也比较高)

(3)casarsa在力量型运动中表现很好,但综合成绩比较差; Drews 综合成绩一般,力量型运动表现非常差。


PCA有很多应用场合,后面我们会介绍更多的例子。


Reference

http://web.stanford.edu/class/stats366/pca.html

http://factominer.free.fr/classical-methods/principal-components-analysis.html

http://gastonsanchez.com/how-to/2012/06/17/PCA-in-R/

http://www.statistik.tuwien.ac.at/public/filz/students/seminar/ws1011/hoffmann_ausarbeitung.pdf

http://planspace.org/2013/02/03/pca-3d-visualization-and-clustering-in-r/

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,874评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,102评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,676评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,911评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,937评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,935评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,860评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,660评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,113评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,363评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,506评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,238评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,861评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,486评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,674评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,513评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,426评论 2 352

推荐阅读更多精彩内容