基因BIN来源分析(一)cd-hit去冗余,salmon计算基因TPM

导读

humann中有一个模块可以进行基因物种来源分析,但是内部怎么分析的。如果能获得每个物种的基因序列文件,那么不用humann也能进行此分析。所以基因BIN来源分析很适合Binning下游分析。

一、合并基因序列ffn文件

mkdir Bin_all/Bin_gene
touch Bin_all/Bin_gene/bin.ffn

echo -e "\033[32m 合并bin.ffn基因序列文件 begin: \033[0m"
for i in Bin_all/Bin_prokka/bin.*; do
    fold=${i##*/}
    cat ${i}/${fold}.ffn >> Bin_all/Bin_gene/bin.fa
    echo -e "\033[32m add ${i}/${fold}.ffn to bin.fa OK\033[0m"
done
echo -e "\033[32m 合并bin.ffn基因序列文件 done... \033[0m"

二、cd-hit去冗余

官网:http://weizhongli-lab.org/cd-hit/
conda 地址:https://anaconda.org/bioconda/cd-hit

参数
M:内存,单位M,默认800
T:线程,默认1
c: identity 0.9 by default

# 安装
conda install -c bioconda cd-hit
cd-hit --help
# CD-HIT version 4.8.1 (built on Apr  7 2021)

echo -e "\033[32m redundant bin.ffn begin: \033[0m"
cd-hit -i Bin_all/Bin_gene/bin.ffn \
-o Bin_all/Bin_gene/out.fa \
-M 400000 \
-T 58 \
-c 0.9
echo -e "\033[32m redundant bin.ffn done... \033[0m"


bin.ffn 260M 但是去冗余后的out.fa也有259M。效果不明显默认的identity(-c)是0.9,调整到0.5-0.9之间的话去冗余效果肯定会更加明显。为了后期能进行基因/物种来源分析不再使用去冗余,主要因为合并bin 基因数并不多,经测试259M2小时搞定基因TPM计算,并不长

参考:
CD-hit安装及使用

三、salmon计算基因TPM

Salmon(硅鱼)是一款新的、极快的转录组计数软件,也被用于宏基因组bin定量(metawarp_quant)。这里我用salmon计算所有bin中预测基因的TPM。

文献:Salmon provides fast and bias-aware quantification of transcript expression
杂志:Nature Methods
时间:2017
Github: https://salmon.readthedocs.io/en/latest/salmon.html

1 构建salmon index

echo -e "\033[32m 构建合并bin基因序列文件salmon索引 begin: \033[0m"
salmon index -t Bin_all/Bin_gene/bin.fa \
-i Bin_all/Bin_gene/bin_index \
--type quasi -k 31 -p 58
echo -e "\033[32m 构建合并bin基因序列文件salmon索引 done... \033[0m"

参数:
-t [ --transcripts ] arg Transcript fasta file
-i [ --index ] arg salmon index
--type arg (=quasi) The type of index to build; the only option is
"quasi" in this version of salmon
-k [ --kmerLen ] arg (=31) The size of k-mers that should be used for the
quasi index

2 计算基因TPM

echo -e "\033[32m salmon计算去合并bin基因丰度 begin: \033[0m"
for i in Bin_all/Clean_data/*_1.fastq; do
    file=${i##*/}
    base=${file%_1.fastq}
    salmon quant --libType A \
    -i Bin_all/Bin_gene/bin_index \
    -1 $i \
    -2 Bin_all/Clean_data/${base}_2.fastq \
    -o Bin_all/Bin_gene/${base}.quant -p 58
    echo -e "\033[32m salmon $base done... \033[0m"
done
echo -e "\033[32m salmon计算合并bin基因TPM done... \033[0m"
某一个样品的salmon quant计算结果

其中的quant.sf文件就是我所需的所有 bin 基因在此样品中的TPM。所以的样品计算完成后通过合并TPM表可得到样品-bin-基因总TPM表。将在以后的博文中继续分享。

3 quant.sf合并
同事合并两组salmon丰度计算结果

# 合并 salmon_1 salmon_2
cat salmon_1/A10_quant.sf | awk -F"\t" '{print $1}' > merge1.out
cat salmon_2/A10_quant.sf | awk -F"\t" '{print $1}' > merge2.out
for i in `ls salmon_1/`;
do
    base=${i%_quant.sf}
    cat salmon_1/$i | sed 's/TPM/'$base'/' | awk -F"\t" '{print $4}' > add1.out
    cat salmon_2/$i | sed 's/TPM/'$base'/' | awk -F"\t" '{print $4}' > add2.out
    paste merge1.out add1.out > tmp1.out
    paste merge2.out add2.out > tmp2.out
    rm add1.out
    rm add2.out
    rm merge1.out
    rm merge2.out
    mv tmp1.out merge1.out
    mv tmp2.out merge2.out
    echo -e "$i done..."
done

参考:
不比对快速估计基因丰度Salmon
FPKM、TPM数据标准化
https://salmon.readthedocs.io/en/latest/salmon.html
https://www.biorxiv.org/content/10.1101/021592v3
FPKM / RPKM与TPM哪个用来筛选差异表达基因更准确?你可别逗了!
TPM可以认为是相对丰度,同一样本内总和为1。
python小脚本:重复行合并求和
python——将大文件切分为多个小文件

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

推荐阅读更多精彩内容