24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 9165  |  回复: 2

小马科研部落

新虫 (小有名气)

[交流] UPGMA聚类 已有1人参与

更多内容请关注微信公众号  小马科研部落
R语言 UPGMA聚类分析

在生态学上,许多物种或环境因子,往往是离散的、不连续的。但许多统计学模型和计算方法往往是针对连续线性的模型。为了让非对称的物种数据可以用这些线性的统计模型,需要将数据进行一些转化。聚类分析也是需要先进行转化的。
UPGMA是微生物多样性分析中常用的聚类分析方法,它属于平均聚合聚类。
用UPGMA分别聚类Jaccard和Bray-Curtis相异系数的思路如下:

首先对原始的物种数据进行转化, decostand();
再计算Jaccard和Bray-Curtis相异系数,vegdist();
用UPGMA方法分别聚类上述相异系数,hclust();
画出聚类图。
其中decostand、vegdist都是vegan包里;hclust是在stats包里。

还是以out表格为例
首先启动R,设置数据的路径
otu1<-read.csv('otu.csv')    #载入数据
otu2<-otu1[1:105,1:16]     #需要1-105行和1-16列  
otu<-t(otu2)              #对数据进行倒置,让样本名在第一列。  
otu                     #得到要分析的数据。


启动vegan和stats包
library(vegan)
library(stats)

计算otu的jaccard和Bray-Curtis相异系数矩阵
otu.norm<-decostand(otu,'normalize')           #将原始数据进行处理
otu.ja<-vegdist(otu.norm,'jac',binary='TRUE')     #计算处理后的数据的Jaccard相异系数矩阵
otu.bc<-vegdist(otu.norm,'bray')            #计算处理后的数据的Bray-Curtis相异系数矩阵   
write.csv(as.matrix(otu.ja),'otuja.csv')        #将jaccard矩阵存为‘otuja.csv’文件
write.csv(as.matrix(otu.bc),'otubc.csv')       #将Bray-Curtis矩阵存为‘otubc.csv’文件

根据UPGMA法聚类Jaccard和Bray-curtis矩阵,并作图
otu.ja.UPGMA<-hclust(otu.ja,method='average')      #聚类Jaccard矩阵
otu.bc.UPGMA<-hclust(otu.bc,method='average')     #聚类Bray-Curtis矩阵
plot(otu.ja.UPGMA)                             #画Jaccard矩阵聚类图
plot(otu.bc.UPGMA)                             #画Jaccard矩阵聚类图

如果想将2幅图放到一页纸上,可以用par(mfrow)命令
par(mfrow=c(1,2))
plot(otu.ja.UPGMA)
plot(otu.bc.UPGMA)


老规矩,还是现在notepad++里编写,在复制到R中进行运算。
此次是本次计算的代码,需要的拿走哈!
otu1<-read.csv('otu.csv')
otu2<-otu1[1:105,1:16]
otu<-t(otu2)
otu

library(vegan)
library(stats)

otu.norm<-decostand(otu,'normalize')
otu.ja<-vegdist(otu.norm,'jac',binary='TRUE')
otu.bc<-vegdist(otu.norm,'bray')
write.csv(as.matrix(otu.ja),'otuja.csv')
write.csv(as.matrix(otu.bc),'otubc.csv')

otu.ja.UPGMA<-hclust(otu.ja,method='average')
otu.bc.UPGMA<-hclust(otu.bc,method='average')
plot(otu.ja.UPGMA)
plot(otu.bc.UPGMA)

par(mfrow=c(1,2))
plot(otu.ja.UPGMA)
plot(otu.bc.UPGMA)

UPGMA聚类
jac和bc 聚类树比较.png
回复此楼

» 猜你喜欢

更多内容,请关注微信公众号【小马科研部落】,有问题可找QQ308091253
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

小马科研部落

新虫 (小有名气)

先自己给自己赞一下
更多内容,请关注微信公众号【小马科研部落】,有问题可找QQ308091253
2楼2017-11-09 14:49:09
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

小野沁沁

新虫 (正式写手)


小木虫: 金币+0.5, 给个红包,谢谢回帖
请问楼主这个怎么做
3楼2018-05-15 11:29:49
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 小马科研部落 的主题更新
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 【求调剂】新能源材料本科,一志愿211,初试321 +6 求调剂学校, 2026-04-02 6/300 2026-04-02 09:41 by 晴空210210
[考研] 282求调剂 +7 呼吸都是减肥 2026-04-01 7/350 2026-04-02 09:10 by vgtyfty
[考研] 266求调剂 +10 阳阳哇塞 2026-04-01 10/500 2026-04-02 09:07 by vgtyfty
[考研] 085410 一志愿211 22408分数359求调剂 +3 123456789qw 2026-03-31 4/200 2026-04-02 00:06 by 义文wang
[考研] 279求调剂 +7 莫xiao 2026-04-01 7/350 2026-04-01 22:05 by 客尔美德
[考研] 307分求调剂 +14 (o~o) 2026-03-31 15/750 2026-04-01 20:43 by longlotian
[考研] 301求调剂 +8 axibli 2026-04-01 8/400 2026-04-01 09:51 by 我的船我的海
[考研] 材料科学与工程求调剂 +13 深V宿舍吧 2026-03-29 13/650 2026-03-31 19:50 by Dyhoer
[考研] 085601 329分调剂 +6 yzsa12 2026-03-31 6/300 2026-03-31 15:23 by yanflower7133
[考研] 一志愿浙江大学工科动力工程370,数一121,专业课135,现在能去哪里 +3 080700调剂 2026-03-30 4/200 2026-03-31 12:00 by KLMY666
[考研] 08工科,295,接受跨专业调剂 +6 lmnlzy 2026-03-30 6/300 2026-03-31 10:04 by cal0306
[考研] 085600,专业课化工原理,320分求调剂 +6 大馋小子 2026-03-29 6/300 2026-03-31 10:03 by 氯化亚硝酰
[考研] 323分 食品与营养调剂 +3 嘿ooo 2026-03-31 3/150 2026-03-31 09:38 by longlotian
[考研] 085701环境工程求调剂 +11 多久上课 2026-03-27 12/600 2026-03-30 21:21 by 研究僧导导
[考研] 105500药学求调剂,一志愿山东大学药学,348分 +3 gr哈哈哈 2026-03-28 3/150 2026-03-30 18:56 by 源_2020
[考研] 求调剂 +10 家佳佳佳佳佳 2026-03-29 10/500 2026-03-30 18:34 by 544594351
[考研] 332求调剂 +6 @MZB382400 2026-03-28 6/300 2026-03-30 16:57 by 无际的草原
[考研] 348求调剂 +6 小懒虫不懒了 2026-03-28 6/300 2026-03-30 10:29 by Evan_Liu
[考研] 本科新能源科学与工程,一志愿华理能动285求调剂 +7 AZMK 2026-03-28 11/550 2026-03-28 21:01 by xxxsssccc
[考研] 352分 化工与材料 +5 海纳百川Ly 2026-03-27 5/250 2026-03-28 03:39 by fmesaito
信息提示
请填处理意见