xydf1992的个人博客分享 http://blog.sciencenet.cn/u/xydf1992

博文

R语言物种多样性计算

已有 17386 次阅读 2018-1-9 21:33 |个人分类:R Language|系统分类:科研笔记| 生态学, R语言, 物种多样性, 植物群落

导入的数据格式如下:


R语言读取数据和计算方法:


library(readxl)

hdata <- read_excel(path = "bcdherb.xlsx", sheet = 1, col_names = T)

hdata <- hdata[,2:91]

#循环计算H值

i <- 1

totalcol <- ncol(hdata)

h <- vector(length = totalcol)

D <- vector(length = totalcol)

J <- vector(length = totalcol)

N <- vector(length = totalcol)

for(i in i:totalcol){

 a <- names(hdata)[i]      #提取数据框表头

 tempdata <- hdata[[a]]    #提取数据框中表头为a的数据Pi

 tempdata <- na.omit(tempdata)

 h[i] <- -1*sum(tempdata*log(tempdata))  #H值计算Shannon-Wiener多样性指数

 D[i] <- 1-sum(tempdata^2)     #Simpson指数

 J[i] <- h[i]/log(length(tempdata))      #Pielou均匀度指数

 N[i] <- length(tempdata)    #有效值个数

}

h

D

J

N

hdataexport <- rbind(hdata,h,D,J,N)

write.csv(hdataexport, file = "bcdherbExport.csv")




https://blog.sciencenet.cn/blog-2438290-1093992.html

上一篇:​利用R语言绘制光谱仪光谱曲线
下一篇:什么时候使用“the”?
收藏 IP: 218.56.38.*| 热度|

0

该博文允许注册用户评论 请点击登录 评论 (1 个评论)

数据加载中...
扫一扫,分享此博文

Archiver|手机版|科学网 ( 京ICP备07017567号-12 )

GMT+8, 2024-12-27 04:13

Powered by ScienceNet.cn

Copyright © 2007- 中国科学报社

返回顶部