从OTU矩阵到Observed_species稀释曲线

#coding

这里是Observed species 稀释曲线的获得方法。它是利用已测得16S rDNA序列中已知的各种OTU的相对比例,来计算抽取n个(n小于测得reads序列总数)reads时出现OTU数量的期望值,然后根据一组n值(一般为一组小于总序列数的等差数列)与其相对应的OTU数量的期望值做出曲线来。

从这个原理看,可以知道的是我们只要定一个随机梯度,对OTU进行随机选取就可以做出这个Observed species的稀释曲线矩阵了。

一般的,OTU表格长这样

rare_c1

首先使用python将这个表格处理成用来作图的矩阵

import random
OTU = open("OTU.txt", "r")
ob = open("observed_species.txt", "w")
ob.write("OTU_Num\tOB\tSamples\n")

# 获得样本名
for line in OTU:
	if line.startswith("Representative_Sequence"):
		nameList = line.split("\n")[0].split("\t")
		nameList.pop(0)
OTU.close()

# 再对每个样本进行统计
for i in range(len(nameList)):
	OTU = open("OTU.txt", "r")
	OTU_list = []
	for line in OTU:
		if line.startswith("Representative_Sequence"):
			continue
		else:
			OTU_num = int(line.split("\t")[i+1])
			n = 0
			while n < OTU_num:
				OTU_list.append(line.split("\t")[0])
				n += 1

	selectNum = 0
	while selectNum < len(OTU_list):
		selectList = random.sample(OTU_list, selectNum)
		output = "\t".join([str(selectNum), str(len(set(selectList))), nameList[i]])
		ob.write(output + "\n")
		selectNum += 1000

	OTU.close()
ob.close()

形成下面这样的矩阵

rare_c2

然后就可以在R里用ggplot2画图啦

library(ggplot2)

num <- read.table("observed_species.txt", sep="\t", header=T)
ggplot(num,aes(x=OTU_Num, y=OB, colour=Samples)) + geom_line() +
  labs(x="Number of Sequences",y="Observed Species", fill="") +
  scale_x_continuous(breaks=c(0, 5000, 10000, 15000, 20000, 25000)) +
  scale_y_continuous(breaks=c(0, 200, 400, 600, 800, 1000, 1200, 1400)) +
  theme_set(theme_bw()) +
  theme(panel.grid.major=element_line(colour=NA)) +
  scale_fill_discrete(name="Samples")

rare_c2

其实还应该把每个样本的对齐,修剪一下的。另外,如果想稀释曲线更加滑溜,可以把梯度调大,或者用ggplot的smooth方法。另外香浓指数稀释等稀释曲线也可以按同样的方式获得矩阵后来画。