This repository contains a nextflow workflow for assembly and annotation of transcripts from Oxford Nanopore cDNA or direct RNA reads. It has been adapted from two existing Snakemake pipelines:
This workflow identifies RNA isoforms using either cDNA or direct RNA (dRNA) Oxford Nanopore reads.
cDNA reads are initially preprocessed by pychopper for the identification of full-length reads, as well as trimming and orientation correction (This step is omitted for direct RNA reads).
Fusion gene detection is performed using JAFFA, with the JAFFAL extension for use with ONT long reads.
Differential gene expression (DGE) and differential transcript usage (DTU) analyses aim to identify genes and/or transcripts that show statistically altered expression patterns in a studied biological system. The results of the differential analyses are presented in a quantitative format and therefore the degree of change (up or down regulation) between experimental conditions can be calculated for each gene identified.
These differential analyses work by taking a “snapshot” of mRNA abundance and calculating the relative levels of transcripts and isoforms. In this context, expression corresponds to the number of messenger RNAs (mRNA) measured from each gene isoform within the organism / tissue / culture being investigated. In order to determine expression levels across the whole genome, sequence data specifically targeting the mRNA molecules can be generated.
Oxford Nanopore Technologies provides a number of sequencing solutions to allow users to generate the required snapshot of gene expression. This can be achieved by both sequencing the mRNA directly, or via a complementary DNA (cDNA) proxy. In contrast to short read sequencing technologies, entire mRNA transcripts can be captured as single reads. The example data provided with this tutorial is from a study based on the PCR-cDNA kit. This is a robust choice for performing differential transcript usage studies. This kit is suitable for preparation of sequence libraries from low mRNA input quantities. The cDNA population is enriched through PCR with low bias; an important prerequisite for the subsequent statistical analysis.
Workflow-transcriptomes includes a subworkflow for DGE and DTU. The first step involves using either a reference alignment or de novo assembly approach to create a set of mRNA sequences per sample. These are merged into a non-redundant transcriptome using stringtie merge. The reads are then aligned to the transcriptome using minimap2 in a splice-aware manner. Salmon is used for transcript quantification, giving per transcript counts and then the following R packages are used for analysis.
DRIMSeq (Nowicka and Robinson (2016)) is used to filter the transcript count data from the salmon analysis. The filter step will be used to select for genes and transcripts that satisfy rules for the number of samples in which a gene or transcript must be observed and minimum threshold levels for the number of observed reads. The parameters used for filtering are defined in the config.yaml file. The default parameters defined for this analysis include
+A statistical analysis is first performed using edgeR (Robinson, McCarthy, and Smyth (2010), McCarthy et al. (2012)) to identify the subset of differentially expressed genes. The filtered list of gene counts is used as input. A normalisation factor is calculated for each sequence library (using the default TMM method - please see McCarthy et al. (2012) for further details). The defined experimental design is used to calculate estimates of dispersion for each of the gene features. Statistical tests are calculated using the contrasts defined in the experimental design. The differentially expressed genes are corrected for false discovery (fdr) using the method of Benjamini & Hochberg (Benjamini and Hochberg (1995))
Differential transcript usage analysis is performed using the R DEXSeq package (Reyes et al. (2013)). Similar to the edgeR package, DEXSeq estimates the variance between the biological replicates and applies generalised linear models for the statistical testing. The key difference is that the DEXSeq method looks for differences at the exon count level. DEXSeq uses the filtered transcript count data prepared earlier in this analysis.
The final component of this isoform analysis is a stage-wise statistical test using the R software package stageR
(Van den Berge and Clement (2018)). stageR uses (1) the raw p-values for DTU from the DEXSeq analysis in the previous section and (2) a false-discovery corrected set of p-values from testing whether individual genes contain at least one exon showing DTU. A hierarchical two-stage statistical testing evaluates the set of genes for DTU.
For the differential expression analysis section you should have at least 3 repeats for each sample. Your fastq data will need to be organised in to 6 directories that represent 3 repeats for each condition. You may also need to provide a condition sheet.
Differential gene expression is sensitive to the input data quantity and quality. There should be equivalence between samples in the number of sequence reads, mapped reads and quality scores. The sequence and alignment summary plots in the report can be used to assess these metrics. There is also a table that shows the transcript per million(TPM) calculated from the salmon counts. TPM normalizes the data for gene length and then sequencing depth, and makes it easier to compare across samples compared to counts.
--de_analysis
).The workflow uses nextflow to manage compute and software resources, as such nextflow will need to be installed before attempting to run the workflow.
The workflow can currently be run using either Docker, Singularity to provide isolation of the required software. Each method is automated out-of-the-box provided either docker or singularity is installed.
It is not required to clone or download the git repository in order to run the workflow. For more information on running EPI2ME Labs workflows visit out website.
To obtain the workflow, having installed nextflow
, users can run:
nextflow run epi2me-labs/wf-transcriptomes --help
to see the options for the workflow.
Download demonstration data
A small test dataset is provided for the purposes of testing the workflow software. It consists of reads, reference, and annotations from human chromosome 20 only. It can be downloaded using:
wget -O test_data.tar.gz https://ont-exd-int-s3-euwst1-epi2me-labs.s3.amazonaws.com/wf-isoforms/wf-isoforms_test_data.tar.gztar -xzvf test_data.tar.gz
Example execution of a workflow for reference-based transcript assembly and fusion detection
OUTPUT=~/output;nexflow run epi2me-labs/wf-transcriptomes \--fastq ERR6053095_chr20.fastq \--ref_genome chr20/hg38_chr20.fa \--ref_annotation chr20/gencode.v22.annotation.chr20.gtf \--jaffal_refBase chr20/ \--jaffal_genome hg38_chr20 \--jaffal_annotation "genCode22" \--out_dir outdir -w workspace_dir
Example workflow for denovo transcript assembly
OUTPUT=~/outputnextflow run . --fastq test_data/fastq \--denovo \--ref_genome test_data/SIRV_150601a.fasta \--out_dir ${OUTPUT} \-w ${OUTPUT}/workspace \--sample sample_id
A full list of options can be seen in nextflow_schema.json. Below are some commonly used ones.
transcript_table_cov_thresh = 50
denovo = true
(default false)--direct_rna
(this just skips the pychopper step).Pychopper and minimap2 can take options via minimap2_opts
and pychopper_opts
, for example:
minimap2_opts = '-uf --splice-flank=no'
pychopper_opts = '-k PCS109'
(default)pychopper_opts = '-k PCS110'
pychopper_opts = '-k PCS111'
pychopper opts = '-m phmm'
pychopper opts = '-m edlib'
Note: edlib is set by default in the config as it’s quite a lot faster. However, it may be less sensitive than nhmmscan.
JAFFAL from the JAFFA package is used to identify potential fusion transcripts.
In order to use JAFFAL, reference files must first be downloaded. To use pre-processed hg38 genome and GENCODE v22 annotation files (as used in the JAFFAL paper) do:
mkdir jaffal_data_dircd jaffal_data_dir/sh path/to/wf-transcriptomes/subworkflows/JAFFAL/download_jaffal_references.sh
Then the path to the directory containing the downloaded reference data must be specified with
--jaffal_refBase
.
Using alternative genome and annotation files
These should be prepared as described here.
The resulting JAFFAL reference files will look something like hg38_genCode22.fa
. The following options enable JAFFAL to find these
files:
--jaffal_genome
optional (default: hg38
)
--jaffal_annotation
optional (default: genCode22
)
Note: JAFFAL is not currently working on Mac M1 (osx-arm64 architecture).
Differential Expression requires at least 2 replicates of each sample to compare. You can see an example condition_sheet.tsv in test_data.
Example workflow for differential expression transcript assembly
The condition sheet should be a .tsv with two columns.
In the default condition_sheet.tsv
available in the test_data directory we have used the following.
eg. condition_sheet.tsv
sample_id,conditionbarcode01,untreatedbarcode02,untreatedbarcode03,untreatedbarcode04,treatedbarcode05,treatedbarcode06,treated
You will also need to provide a reference genome and a reference annotation file. Here is an example cmd to run the workflow. First you will need to download the data with wget. eg.
wget -O differential_expression.tar.gz https://ont-exd-int-s3-euwst1-epi2me-labs.s3.amazonaws.com/wf-isoforms/differential_expression.tar.gz && tar -xzvf differential_expression.tar.gzOUTPUT=~/output;nextflow run epi2me-labs/wf-transcriptomes \--fastq differential_expression/differential_expression_fastq \--de_analysis \--ref_genome differential_expression/hg38_chr20.fa \--ref_annotation differential_expression/gencode.v22.annotation.chr20.gtf \--direct_rna --minimap_index_opts \-k15
You can also run the differential expression section of the workflow on its own by providing a reference transcriptome and setting the transcriptome assembly parameter to false. eg.
nextflow run epi2me-labs/wf-transcriptomes \--fastq differential_expression/differential_expression_fastq \--de_analysis \--ref_genome differential_expression/hg38_chr20.fa \--ref_annotation differential_expression/gencode.v22.annotation.chr20.gtf \--direct_rna --minimap_index_opts \-k15 \--ref_transcriptome differential_expression/ref_transcriptome.fasta \--transcriptome_assembly false
in ${out_dir}/jaffal_output_${sample_id}
you will find:
de_analysis/results_dge.tsv
and de_analysis/results_dge.pdf
- results of edgeR
differential gene expression analysis.de_analysis/results_dtu_gene.tsv
, de_analysis/results_dtu_transcript.tsv
and de_analysis/results_dtu.pdf
- results of differential transcript usage by DEXSeq
.de_analysis/results_dtu_stageR.tsv
- results of the stageR
analysis of the DEXSeq
output.de_analysis/dtu_plots.pdf
- DTU results plot based on the stageR
results and filtered counts.Information