走进转录组生物信息学转录组分析

RNA-seq用hisat2、stringtie、DESeq2分

2019-12-14  本文已影响0人  粥粥zz

一、安装软件

1、HISAT2

将reads比对到基因组上

wget ftp://ftp.ccb.jhu.edu/pub/infphilo/hisat2/downloads/hisat2-2.1.0-Linux_x86_64.zip
unzip hisat2-2.1.0-Linux_x86_64.zip
echo 'export PATH=~/RNA-Seqruanjian/hisat2-2.1.0/bin:$PATH' >> ~/.bashrc

2、StringTie

将比对好的reads进行拼装并预计表达水平

wget http://ccb.jhu.edu/software/stringtie/dl/stringtie-2.0.4.Linux_x86_64.tar.gz
tar -zvxf stringtie-2.0.4.Linux_x86_64.tar.gz
echo 'export PATH=~/RNA-Seqruanjian/stringtie-2.0.4.Linux_x86_64:$PATH' >> ~/.bashrc

3、SAM tools

课上已经用sudo apt install samtools 安装

4、gffcompare

将基因和转录本与注释进行比较,并报告有关此比较的统计数据,确定组装的转录本是否完全或部分地匹配注释的基因,并计算出多少完全是新的

wget http://ccb.jhu.edu/software/stringtie/dl/gffcompare-0.11.5.Linux_x86_64.tar.gz
tar -zxvf gffcompare-0.11.5.tar.gz
echo 'export PATH=~/RNA-Seqruanjian/gffcompare-0.11.5.Linux_x86_64:$PATH' >> ~/.bashrc

5、Deseq2和clusterProfiler

Deseq2:基因差异表达分析的工具,能利用RNA-Seq实验的数据,预测基因、转录本的差异表达
clusterProfiler:富集分析工具

a.安装R环境

sudo vi /etc/apt/sources.list
deb  https://cloud.r-project.org/bin/linux/ubuntu bionic-cran35/
deb https://mirrors.tuna.tsinghua.edu.cn/CRAN/bin/linux/ubuntu/ bionic-cran35/

 lsb_release -a #查看版本
apt-get install software-properties-common dirmngr
sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys E298A3A825C0D65DFD57CBB651716619E084DAB9

sudo apt-get update
sudo apt-get install r-base
sudo apt-get install r-base-dev #一般上一个命令就自动安装好了这个

b.安装DEseq2和clusterProfiler

R     #进入R环境
if (!requireNamespace("BiocManager", quietly = TRUE))
     install.packages("BiocManager")   #安装Bioconductor
options(BioC_mirror="http://mirrors.ustc.edu.cn/bioc/") #bioconductor选择镜像
library(BiocManager)                   #BiocManager加载库
BiocManager::install('DEseq2')
BiocManager::install('org.Hs.eg.db')   #人类注释数据库
BiocManager::install('ggplots') #画图工具包
BiocManager::install('clusterProfiler') #KEGG、GO富集分析工具包

二、找到合适的原始数据和参考基因组及其注释文件

1.在ncbi的SRA数据库找到一个合适的研究,并获取它的原始数据

a.进入SRA Run Selector ,搜索本次实验的数据SRP200940

image.png

b.勾选全部Runs的结果,点击"Accession List"键,下载得到SRR List 储存在SRR_Acc_List 文件中

image.png

c.把SRR_Acc_List 文件上传到虚拟机中

d.批量下载

mkdir Rna-seq-SRP200940  #存放本次实验数据
cd Rna-seq-SRP200940
prefetch   --option-file  SRR_Acc_List .txt
cd ~/ncbi/public/sra/
mv SRR922875*  ~/Rna-seq-SRP200940/

2.下载参考基因组及其注释文件

wget ftp://ftp.ensembl.org/pub/release-75/fasta/homo_sapiens/dna/Homo_sapiens.GRCh37.75.dna_sm.primary_assembly.fa.gz
wget ftp://ftp.ensembl.org/pub/release-75/gtf/homo_sapiens/Homo_sapiens.GRCh37.75.gtf.gz
mv Homo_sapiens.GRCh37.75.dna_sm.primary_assembly.fa.gz genome.fa.gz
mv Homo_sapiens.GRCh37.75.gtf.gz genome.gtf.gz
gunzip *.gz
mkdir GRCh37
mv genome* ./GRCh37

三、解压SRA文件为fastq格式

因为数据比较多,采用批量下载形式

1.新建脚本文件

vi fqdump.sh

2.输入以下脚本

#!/bin/sh
for i in *sra
do
echo $i
fastq-dump --gzip --split-files $i
done

保存退出
这里--gzip参数是为了生成压缩的gz格式fastq文件,以节省磁盘空间

3.运行脚本

sh fqdump.sh

四、用fastqc进行数据质量评价,并使用multiqc整合一下结果

fastqc *fastq.gz
multiqc .

四、用Trimmomatic去重复序列

mkdir trim_out
java -jar ~/Biosofts/Trimmomatic-0.38/Trimmomatic-0.38/trimmomatic-0.38.jar SE -phred33  SRR9228751_1.fastq.gz ./trim_out/SRR9228751_1.clean.fastq.gz  ILLUMINACLIP:/home/zhouqi/Biosofts/Trimmomatic-0.38/Trimmomatic-0.38/adapters/TruSeq2-SE.fa:2:30:10 SLIDINGWINDOW:5:20 LEADING:20 TRAILING:20 MINLEN:75
java -jar ~/Biosofts/Trimmomatic-0.38/Trimmomatic-0.38/trimmomatic-0.38.jar SE -phred33  SRR9228752_1.fastq.gz ./trim_out/SRR9228752_1.clean.fastq.gz  ILLUMINACLIP:/home/zhouqi/Biosofts/Trimmomatic-0.38/Trimmomatic-0.38/adapters/TruSeq2-SE.fa:2:30:10 SLIDINGWINDOW:5:20 LEADING:20 TRAILING:20 MINLEN:75
java -jar ~/Biosofts/Trimmomatic-0.38/Trimmomatic-0.38/trimmomatic-0.38.jar SE -phred33  SRR9228753_1.fastq.gz ./trim_out/SRR9228753_1.clean.fastq.gz  ILLUMINACLIP:/home/zhouqi/Biosofts/Trimmomatic-0.38/Trimmomatic-0.38/adapters/TruSeq2-SE.fa:2:30:10 SLIDINGWINDOW:5:20 LEADING:20 TRAILING:20 MINLEN:75
java -jar ~/Biosofts/Trimmomatic-0.38/Trimmomatic-0.38/trimmomatic-0.38.jar SE -phred33  SRR9228754_1.fastq.gz ./trim_out/SRR9228754_1.clean.fastq.gz  ILLUMINACLIP:/home/zhouqi/Biosofts/Trimmomatic-0.38/Trimmomatic-0.38/adapters/TruSeq2-SE.fa:2:30:10 SLIDINGWINDOW:5:20 LEADING:20 TRAILING:20 MINLEN:75
java -jar ~/Biosofts/Trimmomatic-0.38/Trimmomatic-0.38/trimmomatic-0.38.jar SE -phred33  SRR9228755_1.fastq.gz ./trim_out/SRR9228755_1.clean.fastq.gz  ILLUMINACLIP:/home/zhouqi/Biosofts/Trimmomatic-0.38/Trimmomatic-0.38/adapters/TruSeq2-SE.fa:2:30:10 SLIDINGWINDOW:5:20 LEADING:20 TRAILING:20 MINLEN:75
java -jar ~/Biosofts/Trimmomatic-0.38/Trimmomatic-0.38/trimmomatic-0.38.jar SE -phred33  SRR9228756_1.fastq.gz ./trim_out/SRR9228756_1.clean.fastq.gz  ILLUMINACLIP:/home/zhouqi/Biosofts/Trimmomatic-0.38/Trimmomatic-0.38/adapters/TruSeq2-SE.fa:2:30:10 SLIDINGWINDOW:5:20 LEADING:20 TRAILING:20 MINLEN:75
vi Trimmomatic.sh
for i in *_1.fastq.gz; 
do
i=${i%_1.fastq.gz*}; 
echo ${i};
nohup java -jar ~/Biosofts/Trimmomatic-0.38/Trimmomatic-0.38/trimmomatic-0.38.jar SE -phred33  ${i}_1.fastq.gz  ./trim_out/${i}_1.clean.fastq.gz  ILLUMINACLIP:/home/zhouqi/Biosofts/Trimmomatic-0.38/Trimmomatic-0.38/adapters/TruSeq2-SE.fa:2:30:10 SLIDINGWINDOW:5:20 LEADING:20 TRAILING:20 MINLEN:75 & 
done

五、用hisat2进行比对

1.给参考基因组建立索引

hisat2-build -p 4 genome.fa  genome

-p 线程数

wget   ftp://ftp.ccb.jhu.edu/pub/infphilo/hisat2/data/grch37.tar.gz

2.进行比对

hisat2 -p 4  --dta -x  ~/Rna-seq-SRP200940/GRCh37/genome -U  SRR9228751_1.clean.fastq.gz  -S SRR9228751.sam
hisat2 -p 4  --dta -x  ~/Rna-seq-SRP200940/GRCh37/genome -U  SRR9228752_1.clean.fastq.gz  -S SRR9228752.sam
hisat2 -p 4  --dta -x  ~/Rna-seq-SRP200940/GRCh37/genome -U  SRR9228753_1.clean.fastq.gz  -S SRR9228753.sam
hisat2 -p 4  --dta -x  ~/Rna-seq-SRP200940/GRCh37/genome -U  SRR9228754_1.clean.fastq.gz  -S SRR9228754.sam
hisat2 -p 4  --dta -x  ~/Rna-seq-SRP200940/GRCh37/genome -U  SRR9228755_1.clean.fastq.gz  -S SRR9228755.sam
hisat2 -p 4  --dta -x  ~/Rna-seq-SRP200940/GRCh37/genome -U  SRR9228756_1.clean.fastq.gz  -S SRR9228756.sam
vi hisat2.sh
for i in *1.clean.fastq.gz; 
do
i=${i%_1.clean.fastq.gz*}; 
echo ${i};
nohup hisat2 -p 4 --dta -x ~/Rna-seq-SRP200940/GRCh37/genome -U
${i}_1.clean.fastq.gz  -S ${i}.sam & 
done

-p 线程数
-x 指定基因组索引
--dta 输出转录组型报告 hisat2比对必须加上
-S 指定输出的SAM文件
-U 单端数据文件。若有多组数据,使用逗号将文件分隔。可以和-1、-2参数同时使用,Reads的长度可以不一致
-1 <m1>双端测序结果的第一个文件。若有多组数据,使用逗号将文件分隔。Reads的长度可以不一致。
-2 <m2>双端测序结果的第二个文件。若有多组数据,使用逗号将文件分隔,并且文件顺序要和-1参数对应。Reads的长度可以不一致。

六、利用samtools对sam格式的比对文件进行处理

1.为参考基因组建立索引

samtools  faidx genome.fna 

2.将sam格式转换为二进制格式bam

samtools view -bhS -t ~/Rna-seq-SRP200940/GRCh37/genome.fa.fai  -@ 2 -o SRR9228751.bam SRR9228751.sam 
samtools view -bhS -t ~/Rna-seq-SRP200940/GRCh37/genome.fa.fai  -@ 2 -o SRR9228752.bam SRR9228752.sam 
samtools view -bhS -t ~/Rna-seq-SRP200940/GRCh37/genome.fa.fai  -@ 2 -o SRR9228753.bam SRR9228753.sam 
samtools view -bhS -t ~/Rna-seq-SRP200940/GRCh37/genome.fa.fai  -@ 2 -o SRR9228754.bam SRR9228754.sam 
samtools view -bhS -t ~/Rna-seq-SRP200940/GRCh37/genome.fa.fai  -@ 2 -o SRR9228755.bam SRR9228755.sam 
samtools view -bhS -t ~/Rna-seq-SRP200940/GRCh37/genome.fa.fai  -@ 2 -o SRR9228756.bam SRR9228756.sam 
vi view.sh
for i in *.sam;
do 
i=${i%.sam*};
echo ${i};
nohup samtools view -bhS  -t ~/Rna-seq-SRP200940/GRCh37/genome.fa.fai -@ 2 -o ${i}.bam ${i}.sam & 
done

-b output BAM 默认下输出的是SAM格式,这参数设置输出为BAM格式
-h print header for the SAM output 默认下输出的 sam 格式文件不带 header,该参数设定输出sam文件时带 header 信息
-S input is SAM 默认下输入是 BAM 文件,若是输入是 SAM 文件,则最好加该参数,否则有时候会报错。
-t file list of reference names and lengths (force -S) 使用一个list文件来作为header的输入
-@ Number of additional threads to use [0] 指使用的线程数
-o FILE output file name [stdout] 输出文件的名称
<https://www.jianshu.com/p/6b7a442d293f>

3.对 bam 文件中的内容进行排序

 samtools sort -@ 4  -o SRR9228751.sort.bam  SRR9228751.bam
 samtools sort -@ 4  -o SRR9228752.sort.bam  SRR9228752.bam
 samtools sort -@ 4  -o SRR9228753.sort.bam  SRR9228753.bam
 samtools sort -@ 4  -o SRR9228754.sort.bam  SRR9228754.bam
 samtools sort -@ 4  -o SRR9228755.sort.bam  SRR9228755.bam 
 samtools sort -@ 4  -o SRR9228756.sort.bam  SRR9228756.bam
vi sort.sh
for i in *.bam;
do 
i=${i%.bam*};
echo ${i};
nohup samtools sort -@ 4 -o ${i}.sort.bam ${i}.bam & 
done

4.可视化比对结果

a、先对排序后的bam文件进行索引

samtools index SRR9228751.sort.bam
samtools index SRR9228752.sort.bam
samtools index SRR9228753.sort.bam
samtools index SRR9228754.sort.bam
samtools index SRR9228755.sort.bam
samtools index SRR9228756.sort.bam

b、可视化结果

samtools tview SRR9228751.sort.bam ~/Rna-seq-SRP200940/GRCh37/genome.fa
samtools tview SRR9228752.sort.bam ~/Rna-seq-SRP200940/GRCh37/genome.fa
samtools tview SRR9228753.sort.bam ~/Rna-seq-SRP200940/GRCh37/genome.fa
samtools tview SRR9228754.sort.bam ~/Rna-seq-SRP200940/GRCh37/genome.fa
samtools tview SRR9228755.sort.bam ~/Rna-seq-SRP200940/GRCh37/genome.fa
samtools tview SRR9228756.sort.bam ~/Rna-seq-SRP200940/GRCh37/genome.fa

七、利用StringTie进行转录本组装,和量化基因表达

1.对样本进行组装

比对上的reads将会被呈递给StringTie进行转录本组装,StringTie单独的对每个样本进行组装,在组装的过程中顺带估算每个基因及isoform的表达水平

stringtie -p 4  -G  ~/Rna-seq-SRP200940/GRCh37/genome.gtf -o SRR9228751.gtf -l SRR9228751 SRR9228751.sort.bam
stringtie -p 4  -G  ~/Rna-seq-SRP200940/GRCh37/genome.gtf -o SRR9228752.gtf -l SRR9228752 SRR9228752.sort.bam
stringtie -p 4  -G  ~/Rna-seq-SRP200940/GRCh37/genome.gtf -o SRR9228753.gtf -l SRR9228753 SRR9228753.sort.bam
stringtie -p 4  -G  ~/Rna-seq-SRP200940/GRCh37/genome.gtf -o SRR9228754.gtf -l SRR9228754 SRR9228754.sort.bam
stringtie -p 4  -G  ~/Rna-seq-SRP200940/GRCh37/genome.gtf -o SRR9228755.gtf -l SRR9228755 SRR9228755.sort.bam
stringtie -p 4  -G  ~/Rna-seq-SRP200940/GRCh37/genome.gtf -o SRR9228756.gtf -l SRR9228756 SRR9228756.sort.bam

-p 线程(CPU)数 (default: 1)
-G 参考序列的基因注释文件 (GTF/GFF3)
-l 输出转录本的名称前缀(默认为MSTRG)

vi stringtie1.sh
for i in *sort.bam; 
do 
i=${i%.sort.bam*}; 
echo ${i};
nohup stringtie -p 4 -G  ~/Rna-seq-SRP200940/GRCh37/genome.gtf 
 -o ${i}.gtf -l  ${i} ${i}.sort.bam & 
done

2.将所有转录本合并

所有的转录本都被呈递给StringTie的merge函数进行merge,这一步是必须的,因为有些样本的转录本可能仅仅被部分reads覆盖,无法被StringTie组装出来。merge步骤可以创建出所有样本里面都有的转录本
<链接:https://www.jianshu.com/p/1f5d13cc47f8>

vi mergelist.txt  #需要包含之前output.gtf文件的路径
SRR9228751.gtf
SRR9228752.gtf
SRR9228753.gtf
SRR9228754.gtf
SRR9228755.gtf
SRR9228756.gtf
stringtie --merge -p 4 -G ~/Rna-seq-SRP200940/GRCh37/genome.gtf  -o stringtie_merged.gtf  mergelist.txt

-p 线程(CPU)数 (default: 1)
-G <guide_gff> 参考转录本的注释信息 (GTF/GFF3)

3.检测相对于注释基因组,转录本的组装情况

使用gffCompare实用程序来确定有多少组合的转录本完全或部分匹配带注释的基因,并计算出有多少是完全新颖的

gffcompare -r  ~/Rna-seq-SRP200940/GRCh37/genome.gtf  -G  -o merged stringtie_merged.gtf

-r 参考转录本的注释信息
-G 比对所有转录本
-0 指定要用于gffcompare将创建的输出文件的前缀

4.重新组装转录本并估算基因表达丰度

stringtie –e –B -p 4 -G stringtie_merged.gtf -o ballgown/SRR9228751/SRR9228751.gtf  SRR9228751.sort.bam
stringtie –e –B -p 4 -G stringtie_merged.gtf -o ballgown/SRR9228752/SRR9228752.gtf  SRR9228752.sort.bam
stringtie –e –B -p 4 -G stringtie_merged.gtf -o ballgown/SRR9228753/SRR9228753.gtf  SRR9228753.sort.bam
stringtie –e –B -p 4 -G stringtie_merged.gtf -o ballgown/SRR9228754/SRR9228754.gtf  SRR9228754.sort.bam
stringtie –e –B -p 4 -G stringtie_merged.gtf -o ballgown/SRR9228755/SRR9228755.gtf  SRR9228755.sort.bam
stringtie –e –B -p 4 -G stringtie_merged.gtf -o ballgown/SRR9228756/SRR9228756.gtf  SRR9228756.sort.bam
vi chongzuzhuang.sh
for i in *.sort.bam; 
do 
i=${i%.sort.bam*}; 
echo ${i};
nohup stringtie -e -B -p 8 -G stringtie_merged.gtf -o ballgown/${i}/${i}.gtf  ${i}.sort.bam & 
done

-e 只对参考转录本进行丰度评估 (requires -G)
-G 参考序列的基因注释文件 (GTF/GFF3)
-B 在输出的GFT同目录下输出Ballgown table 文件

八、利用DEseq2进行基因差异表达分析

1.stringtie输出的结果为ballgown所需要的格式,需要转换为deseq2需要的表格

a.下载一个python脚本prepDE.py

wget  http://ccb.jhu.edu/software/stringtie/dl/prepDE.py

b.转换格式

python2 ./prepDE.py - ballgown

2.用DESeq2分析

R
library(DESeq2)
#导入数据
CountMatrix1<-read.csv("gene_count_matrix.csv",sep=",",row.names="gene_id") 
##修改列名
names(CountMatrix1)<-c("ctrlrep1","ctrlrep2","ctrlrep","  ISrep1","ISrep2","ISrep3") 
#设置样本信息矩阵,包括处理信息:实验组ctrlrep vs. 对照组ISrep,每个有3个
ColumnData<- data.frame(row.names=colnames(CountMatrix1),samName=colnames(CountMatrix1), condition=rep(c("ctrlrep","ISrep"),each=3)) 
 #生成DESeqDataSet数据集
dds<-DESeqDataSetFromMatrix(countData = CountMatrix1, colData = ColumnData, design = ~ condition)
#DESeq差异表达计算
dds<-DESeq(dds) 
#生成差异表达结果
res<-results(dds)  
summary(res) 
#查看总结信息(表达上调,下调等)
head(res) 
#统计padj(adjusted p-value)小于0.05的数目
table(res$padj <0.05)
#统计padj(adjusted p-value)小于0.05的数目
res<- res[order(res$padj),]#按padj排序
resdata <- merge(as.data.frame(res), as.data.frame(counts(dds, normalized=TRUE)),by="row.names",sort=FALSE)
write.csv(resdata,file = "SRP200940.csv")
#输出结果到csv文件
deg <- subset(res, padj <= 0.01 & abs(log2FoldChange) >= 1) #筛选显著差异表达基因(padj小于0.01且FoldChange绝对值大于2)
summary(deg) #查看筛选后的总结信息
write.csv(deg, "SRP200940.deg.csv") #将差异表达显著的结果输出到csv文件

3.用ggplots作图

library(ggplot2)
volcano<- ggplot(resdata, aes(x= log2FoldChange, y= -1*log10(padj)))
#x轴为log2FC;y轴为-log(padj)
threshold<-as.factor(resdata$padj <= 0.01 & abs(resdata$log2FoldChange) >= 2)
#筛选条件(阈值):绝对log2FC大于2,并且padj<0.01
p1<-volcano+geom_point(aes(color=threshold)) 
p1
#加上各数据点信息
p2<-p1+scale_color_manual(values=c("grey","red"))
p2
#更改散点颜色
p3<-p2+geom_hline(yintercept=2,linetype=3)+geom_vline(xintercept=c(-2,2),linetype=3)
p3
#加上水平和垂直线,标识阈值选择范围
p4<-p3+theme(axis.line=element_line(colour="black"),panel.background = element_rect(fill = "white"))
p4
#修改图片背景填充颜色,坐标轴线条颜色
degs <- subset(resdata, padj <= 0.01 & abs(log2FoldChange)>= 2) 
p5<-p4+geom_text(aes(label=degs$Row.names),hjust=1, vjust=0,data = degs)
p5
#绘制P-value图
hist(deg$pvalue,breaks=10,col="grey",xlab="p-value")
#绘制MA图
plot(deg$log2FoldChange,-log2(deg$padj),col=ifelse(abs(deg$log2FoldChange) >= 2 & abs(deg$padj) <= 0.05,"red","black"),xlab="log2FoldChange",ylab="-log2Pvalue")

九、利用clusterProfiler进行基因差异表达分析

把SRP200940.deg.csv下载用excel筛选只剩下id和foldchange
并在https://david.ncifcrf.gov/conversion.jsp进行id转换为genesymbol

library(org.Hs.eg.db)           #人类注释数据库
library(ggplot2)                #画图工具包
library(clusterProfiler)        #KEGG、GO富集分析工具包
#读入差异表达基因列表,并且需要标题行
geneList <- read.table("SRP200940.deg.txt",header=TRUE)         
#将基因列表的gene Symbol 转换成 entrez ID
geneID <- bitr(as.character(geneList$geneSymb),fromType="SYMBOL",toType=c("ENTREZID"),OrgDb=org.Hs.eg.db) 
#差异表达基因的功能富集分析
KEGGenrich <- enrichKEGG(geneID$ENTREZID,organism='hsa',pvalueCutoff = 0.05) 
write.csv(summary(KEGGenrich),"GeneEnrichment_results.csv")
#kegg柱状图绘制
pdf("Gene_KEGGenrichment_barplot.pdf")
barplot(KEGGenrich,title="KEGG enrichment")
dev.off()
#GO 富集分析
enrichBP <- enrichGO(geneID$ENTREZID,OrgDb=org.Hs.eg.db,ont="BP",pvalueCutoff = 0.05)  #分析生物学过程方面           
enrichMF <- enrichGO(geneID$ENTREZID,OrgDb=org.Hs.eg.db,ont="MF",pvalueCutoff = 0.05) #分析分子功能方面                                            
enrichCC <- enrichGO(geneID$ENTREZID,OrgDb=org.Hs.eg.db,ont="CC",pvalueCutoff = 0.05)  #分析细胞组成方面                                                     
#查看富集结果的个数:
dim(enrichBP)
dim(enrichMF)
dim(enrichCC)
#柱状图绘制
#BP
pdf("Gene_GOenrichBP_barplot.pdf")
barplot(enrichBP,title="GOenrichBP")
dev.off()
#MF
pdf("Gene_GOenrichMF_barplot.pdf")
barplot(enrichMF,title="GOenrichMF")
dev.off()
#CC
pdf("Gene_GOenrichCC_barplot.pdf")
barplot(enrichCC,title="GOenrichCC")
dev.off()

·:

上一篇 下一篇

猜你喜欢

热点阅读