R的PCA

主成分分析R软件实现程序(一):

>d=read.table("clipboard",header=T) #从剪贴板读取数据

>sd=scale(d)  #对数据进行标准化处理

>sd  #输出标准化后的数据和属性信息,把标准化的数据拷贝到剪贴板备用

>d=read.table("clipboard",header=T) #从剪贴板读取标准化数据

>pca=princomp(d,cor=T)  #主成分分析函数

>screeplot(pca,type="line",mian="碎石图",lwd=2) #画出碎石图

从碎石图上可以看出,前两个主成分的方差贡献率比重比较大,下面计算前两个主成分的累积方差贡献率是否超过80%……

>dcor=cor(d) #求相关矩阵

>deig=eigen(dcor)  #求相关矩阵的特征值和特征向量

>deig$values #输出特征值

>sumeigv=sum(deig$values)

>sumeigv   得到k值

>sum(deig$values[1:2])/k #求前两个主成分的累积方差贡献率

>pca$loadings[,1:2]  #输出前2个主成分的载荷系数

观察载荷系数可以得到:主成分C1在……

>deig$values[1]/k;deig$values[2]/k; #计算主成分C1、C2的系数b1、b2

C=(b1*C1+b2*C2)/(b1+b2)=q1*C1+q2*C2

>s=pca$scores[,1:2] #输出前两个主成分的得分

>c=s[1:评价对象的个数,1]*q1+s[1:评价对象的个数,2]*q2

>cbind(s,c)

然后把综合得分c的值从小到大排序,得到最后评价结果。

注意:在这里c的值指的是c的实数的值,并非绝对值。

 

主成分分析R软件实现程序(二):

在excel中点击复制要读取的文件

>data<-read.table("clipboard",header=T,sep='\t')

>data

>data.pr<-princomp(data,cor=TRUE)#data为数据矩阵或数据框,cor为是否用相关阵,默认为协差阵,scores为是否输出成分得分

>summary(data.pr,loading=TRUE)#loading=TURE选项列出了主成分对应原始变量的系数

  其中:standard deviation 标准偏差 Porportion ofVariance 贡献率(方差比例)

      comulative proportion 累计贡献率(累计比例)

画出三种碎石图:

>screeplot(data.pr)  #条型

>biplot(data.pr)   #分散型

>screeplot(data.pr,type=("line"))  #线型

PCAPrincipal Component Analysis,主成分分析)是一种常用的数据降维技术,可以帮助我们在高维数据中找到最主要的特征。在R语言中,我们可以使用`prcomp()`函数来进行PCA分析。 首先,我们需要准备数据。数据应该是一个矩阵或数据框,其中每一列是一个变量,每一行是一个观测值。假设我们有一个环境因子的数据集,其中包含多个环境变量(如温度、湿度、光照等)和观测点(样本)。我们可以将数据读取到R中,并将其格式化为合适的矩阵或数据框。 然后,我们可以使用`prcomp()`函数进行PCA分析。这个函数接受一个数据矩阵或数据框作为输入,并返回一个PCA对象。我们可以将这个对象保存在一个变量中,以便后续的分析和可视化。 例如,假设我们的数据矩阵名为`env_data`,其中有4个环境变量和100个观测点。我们可以使用以下代码进行PCA分析: ```R pca_result <- prcomp(env_data) ``` 在这个例子中,`pca_result`是保存PCA结果的变量。我们可以使用`summary()`函数来查看分析的摘要信息,例如各主成分的方差解释比例和贡献度,以及每个环境变量在主成分中的负荷。 ```R summary(pca_result) ``` 我们还可以使用`plot()`函数将PCA结果可视化,例如绘制主成分的方差解释比例图和负荷图。 ```R plot(pca_result) ``` 这样,我们就可以使用R语言中的PCA函数(`prcomp()`)对环境因子进行分析,并得到相应的结果和可视化图形。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值