nf-core/rnasplice
rnasplice is a bioinformatics pipeline for RNA-seq alternative splicing analysis
Pipeline parameters
Please provide pipeline parameters via the CLI or Nextflow -params-file
option. Custom config files including those provided by the -c
Nextflow option can be used to provide any configuration except for parameters; see docs.
Samplesheet input
You will need to create a samplesheet with information about the samples you would like to analyse before running the pipeline. Use this parameter to specify its location.
The samplesheet has to be a comma-seperated file with at least 3 columns, and a header row as shown in the example below.
The samplesheet can have as many columns as you desire, however, there is a strict requirement for at least 3 columns to match those defined in the table below.
Column | Description |
---|---|
sample | Custom sample name. This entry will be identical for multiple sequencing libraries/runs from the same sample. Spaces in sample names are automatically converted to underscores (_ ). |
fastq_1 | Full path to FastQ file for Illumina short reads 1. File has to be gzipped and have the extension “.fastq.gz” or “.fq.gz”. |
fastq_2 | Full path to FastQ file for Illumina short reads 2. File has to be gzipped and have the extension “.fastq.gz” or “.fq.gz”. |
strandedness | Sample strand-specificity. Must be one of unstranded , forward or reverse . |
condition | The name of the condition a sample belongs to (e.g. ‘control’, or ‘treatment’) - these labels will be used for downstream analysis. |
genome_bam | Full path to aligned BAM file, derived from splicing aware mapper (STAR, HiSat, etc). File has to be in “.bam” format. |
transcriptome_bam | Full path to aligned transcriptome file, derived from splicing aware mapper (STAR, HiSat, etc). File has to be in “.bam” format. |
salmon_results | Full path to the result folder produced by salmon quantification. |
Source configuration
The pipeline can be started from four sources of input data. Use this parameter to specify the input source.
FASTQ files
The default configuration is --source fastq
and takes compressed or uncompressed reads files as the input source. The samplesheet must have the 5 columns shown in the example below.
This configuration allows the pipeline to run all downstream analysis methods.
Genome BAM files
The --source genome_bam
configuration takes genome BAM files derived from a splice aware mapper (STAR, HiSat, etc). The samplesheet must have the 3 columns shown in the example below.
This configuration allows the pipeline to run the “dexseq_exon”, “edger_exon” and “rmats” analysis methods.
Transcriptome BAM files
The --source transcriptome_bam
configuration takes transcriptome BAM files files derived from a splice aware mapper (STAR, HiSat, etc). The samplesheet must have the 3 columns shown in the example below.
This configuration allows the pipeline to run the “dexseq_dtu” and “suppa” analysis methods.
Salmon quantification files
The --source salmon_results
configuration takes the output quantification directories produced by Salmon. The samplesheet must have the 3 columns shown in the example below.
This configuration allows the pipeline to run the “dexseq_dtu” and “suppa” analysis methods.
Contrastsheet input
You will also need to create a contrastsheet with information about the contrasts you would like to analyse before running the pipeline. Use this parameter to specify its location.
The contrastsheet has to be a comma-separated file with 3 columns, and a header row as shown in the examples below.
The contrastsheet can have as many columns as you desire, however, there is a strict requirement for the first 3 columns to match those defined in the table below.
Column | Description |
---|---|
contrast | An arbitrary identifier, will be used to name contrast-wise output files. |
treatment | The treatment/target level for the comparison. |
control | The control/base level for the comparison. |
An example contrastsheet has been provided with the pipeline.
Alignment options
The pipeline offers the use of STAR (i.e. --aligner star
) to map raw FastQ reads to a reference genome and to project the alignments onto the transcriptome. Downstream quantification can also be performed following STAR alignment with Salmon when --aligner star_salmon
is chosen. Users may wish to perform STAR alignment without Salmon quantification when certain downstream tools (e.g. rMATS) only require BAM files as input. By default intermediate SAM alignment files are not saved for space efficiency reasons. This behaviour can be overriden with the --save_align_intermeds
parameter. Users should take note that STAR requires a lot of memory (~38GB Human GRch37).
Although STAR is fast, users may wish to choose an even faster option by choosing to psuedo-align and quantify with Salmon alone by providing the --pseudo_aligner salmon
parameter. This may be a good option if users do not need to generate BAM files and downstream tools are compatible with this process (e.g. Differential transcript usage using DEXSeq, or Event-based approach SUPPA). It should be noted, however, that by defining the parameter --pseudo_aligner salmon
, users will run Salmon in addition to the standard workflow defined by the --aligner
parameter. This is in keeping with the nf-core/rnaseq approach, and Salmon can be run in isolation with the addition of the --skip_alignment
parameter. Furthermore, the pipeline, like nf-core/rnaseq will generate transcript fasta and Salmon index files from gtf and genome fasta files by default. Users can supply these files, however, if they wish to override this auto-generation using the --transcript_fasta
and --salmon_index
parameters. Additional Salmon paramaters can be specified at run-time if users wish. For example, library preparation protocol (library type) by default is inferred from samplesheet information, but can also be specified using the --salmon_quant_libtype
parameter. You can find additional library type details in the Salmon documentation.
Quantification options
As discussed above users may wish to align with STAR by providing the --aligner
parameter, or pseudo-align with Salmon by providing the --pseudo_aligner salmon
parameter.
There are 3 methods for quantification after STAR alignment:
Already discussed above is quantification using Salmon by providing the --aligner star_salmon
parameter. This enables access to tools which require Salmon for quantification (e.g. Differential transcript usage using DEXSeq, or Event-based approach SUPPA)
The pipeline also enables quantification using featureCounts. This is needed for differential exon usage analysis using edgeR and is activated when the parameter --edger_exon
is enabled. Please note that as this is aimed at differential exon usage feature type is set as exon
and cannot be changed. Please take care to use a suitable attribute to categorize the featureCounts attribute type in your GTF using the option --gtf_group_features
(default: gene_id
).
The final quantification method following STAR alignment is with HTSeq which is implemented as part of the DEXSeq package. This is needed for differential exon usage analysis using DEXSeq and is activated when the parameter --dexseq_exon
is enabled. Using the --aggregation
parameter the pipeline will combine overlapping genes into a single aggregate gene. This approach can alternatively be skipped and any exons that overlap other exons from different genes will be skipped. Other important options to take note of are the --alignment_quality
parameter which can be set by the user and defines the minimum alignment quality required for reads to be included (defined in 5th column of a given SAM file) (default: 10). Prior to quantification, DEXSeq provides an annotation preparation script which takes a GTF file as input and returns a GFF file. Users may instead wish to define their own GFF file and skip this annotation preparation skip by supplying it using the --gff_dexseq
parameter.
Reference genome files
Like nf-core/rnaseq the minimum reference genome requirements are a FASTA and GTF file. All other files required to run the pipeline can be generated from these files. If you wish to build new indices and save the output then the --save_reference
parameter is required. It should be noted, however, that the sequence files and indices of many common species are available for download from AWS iGenomes). Local copies of reference files may also be provided on the command line or via config files (e.g. --salmon_index '/path/to/salmon_index.tar.gz'
). Where reference files are compressed (e.g. standard files with the .gz
extension and indices folders with the tar.gz
extension) these will be automatically uncompressed prior to use.
For nf-core/rnasplice to run it requires a FASTA file and GTF file. These can be specified manually, however users may wish to use the more simple AWS iGenomes) approach:
- Using the
--genome
parameter followed by the genome build (e.g. GRCh37) will mean the FASTA and GTF file will be pulled from AWS-iGenomes, along with available indices required for a given analysis. Furthermore, a local download of AWS genomes from a previous run can also be used by changing the igenomes path with the--igenomes_base
parameter.
If a GTF is not available a GFF may be used by specifying the --gff
parameter. This will convert the GFF file into a GTF.
As in nf-core/rnaseq if you are using a genome downloaded from AWS iGenomes and using --aligner star_salmon
(default) the version of STAR to use for the alignment will be auto-detected (see #808).
Please note if you are using GENCODE reference genome files please specify the --gencode
parameter. This is because reference files which come from GENCODE are different to ENSEMBL reference files and this can impact the running of the pipeline. Specifying this parameter can help to mitigate these differences. Furthermore it should be noted that when using GENCODE reference files if you are running Salmon, the --gencode
flag will also be passed to the index building step (see this issue).
Differential Exon Usage
Differential exon usage (DEU) can be performed with two different branches of the pipeline:
DEXSeq
Following HTSeq quantification you can estimate the differential exon usage using DEXSeq. This can be chosen by specifying the --aligner star
or --aligner star_salmon
followed by the --dexseq_exon
parameter.
edgeR
Following featureCounts quantification differential exon usage can also be performed with edgeR. This can be chosen by specifying the --aligner star
or --aligner star_salmon
followed by the --edger_exon
parameter. This module also produces differential exon expression results for each contrast.
Differential Transcript Usage
DEXSeq
Differential transcript Usage (DTU) has been implemented from the workflow by Love et al., 2018. This analysis can be chosen by specifying the --aligner star_salmon
or --pseudo_aligner salmon
followed by the --dexseq_dtu
parameter. The parameter --dtu_txi
should either be set as --dtu_txi scaledTPM
or --dtu_txi dtuScaledTPM
for successful DTU analysis.
Prior to DEXSeq DTU analysis, filtering of genes and features with low expression is completed using DRIMSeq which comes with a number of parameters which should be set by the user. By default these are all set to 0. For example, --min_samps_gene_expr
defines the minimal number of samples where genes are required to be expressed, and --min_gene_expr
defines the minimal level of gene expression for genes to be included in the downstream analysis. Similarly, --min_samps_feature_expr
and --min_samps_feature_prop
defines the minimal number of samples where features are required to be expressed at a minimal expression or proportion. This minimum level is further defined by additional filtering parameters --min_feature_expr
and --min_feature_prop
respectively. Further details of this filtering process can be see within the DTU workflow here.
IsoformSwitchAnalyzeR
IsoformSwitchAnalyzeR as described by Vitting-Seerup et al., 2019 performs a genome-wide analysis of splicing patterns and identifies isoform switches. It takes a salmon results directory as input so either --source fastq
or --source salmon_results
must be given. Two parameters can be set:
--isoformswitchanalyzer_alpha
sets the significance threshold and --isoformswitchanalyzer_dIF
sets the minimum absolute difference in isoform usage.
Event based approaches
Two predominant event-based approaches have been implemented (rMATS and SUPPA) in this pipeline and can be accessed through --aligner
or --pseudo_aligner
options:
rMATS
rMATS (Replicate Multivariate Analysis of Transcript Splicing) is used to detec differential alternative splicing from replicated RNA-Seq data. If --aligner
is set to --aligner star
or --aligner star_salmon
then rMATS can be executed with the --rmats
parameter.
At current, however, there are some restrictions to running an rMATS analysis:
-
Samples need to have the same strandedness and read type (single-end/paired-end).
-
The
--rmats_paired_stats
can be set totrue
only if there are two conditions.
Furthermore, --rmats_read_len
has to be set by the user and if the read length is variable, an average or median read length has to be specified.
SUPPA2
You can run SUPPA for analyzing splicing events across conditions following pseudo alignment and quantification with Salmon --pseudo_aligner salmon
or after STAR alignment and Salmon quantification --aligner star_salmon
, and when the --suppa
parameter is supplied.
There are two main options for running an analysis with SUPPA - --suppa_per_local_event
and --suppa_per_isoform
(the latter is a DTU approach). When --suppa_per_local_event
is set to true
, local AS events are calculated and analyzed. When --suppa_per_isoform
is set to true
, transcript isoform events are calculated and analyzed.
Event Calculation
Events are calculated from user specified annotation files (e.g. GTF files). The parameter --pool_genes
should be specified when creating ioe/ioi from annotations that are not loci-based. It should be noted that SUPPA advises users to use Ensembl and Gencode annotations to reduce errors at this stage of the analysis.
The --local_events
parameter requires users to choose the type of events to focus analysis on. They can be any (or all) from the following list (e.g. --local_events SE SS MX RI FL
):
- SE: Skipping exon (SE) events
- SS: Alternative 5’ (A5) and 3’ (A3) splice sites (it generates both)
- MX: Mutually Exclusive (MX) exons
- RI: Retained intron (RI)
- FL: Alternative first (AF) and last (AL) exons (it generates both)
PSI Calculation
For local events
, SUPPA reads the ioe
file generated in the event calculation step and a transcript expression file with the transcript abundances (TPM units) to calculate the relative abundance (PSI) value per sample for each event. It generates a psi file.
For transcript isoform events
, SUPPA reads the annotation file and a transcript expression file with the transcript abundances (TPM units) to calculate the relative abundance (PSI) value per sample for each event. It generates a psi file.
Differential Splicing Analysis
The PSI
files and TPM
files are split based on the condition specified in metadata. e.g., condition1.psi, condition2.psi, condition1.tpm, condition2.tpm.
SUPPA then reads the PSI
for the events and the transcript expression values from multiple samples, grouped by condition, and the ioe
/ioi
file, to calculate the events that are differentially spliced between a pair of conditions.
Cluster Analysis
Using dpsi
file and psivec
file, events are clustered according to PSI
values across conditions.
Running the pipeline
The typical command for running the pipeline is as follows:
This will launch the pipeline with the docker
configuration profile. See below for more information about profiles.
Note that the pipeline will create the following files in your working directory:
If you wish to repeatedly use the same parameters for multiple runs, rather than specifying each flag in the command, you can specify these in a params file.
Pipeline settings can be provided in a yaml
or json
file via -params-file <file>
.
Do not use -c <file>
to specify parameters as this will result in errors. Custom config files specified with -c
must only be used for tuning process resource specifications, other infrastructural tweaks (such as output directories), or module arguments (args).
The above pipeline run specified with a params file in yaml format:
with params.yaml
containing:
You can also generate such YAML
/JSON
files via nf-core/launch.
Updating the pipeline
When you run the above command, Nextflow automatically pulls the pipeline code from GitHub and stores it as a cached version. When running the pipeline after this, it will always use the cached version if available - even if the pipeline has been updated since. To make sure that you’re running the latest version of the pipeline, make sure that you regularly update the cached version of the pipeline:
Reproducibility
It is a good idea to specify a pipeline version when running the pipeline on your data. This ensures that a specific version of the pipeline code and software are used when you run your pipeline. If you keep using the same tag, you’ll be running the same version of the pipeline, even if there have been changes to the code since.
First, go to the nf-core/rnasplice releases page and find the latest pipeline version - numeric only (eg. 1.3.1
). Then specify this when running the pipeline with -r
(one hyphen) - eg. -r 1.3.1
. Of course, you can switch to another version by changing the number after the -r
flag.
This version number will be logged in reports when you run the pipeline, so that you’ll know what you used when you look back in the future. For example, at the bottom of the MultiQC reports.
To further assist in reproducbility, you can use share and re-use parameter files to repeat pipeline runs with the same settings without having to write out a command with every single parameter.
If you wish to share such profile (such as upload as supplementary material for academic publications), make sure to NOT include cluster specific paths to files, nor institutional specific profiles.
Core Nextflow arguments
These options are part of Nextflow and use a single hyphen (pipeline parameters use a double-hyphen).
-profile
Use this parameter to choose a configuration profile. Profiles can give configuration presets for different compute environments.
Several generic profiles are bundled with the pipeline which instruct the pipeline to use software packaged using different methods (Docker, Singularity, Podman, Shifter, Charliecloud, Apptainer, Conda) - see below.
We highly recommend the use of Docker or Singularity containers for full pipeline reproducibility, however when this is not possible, Conda is also supported.
The pipeline also dynamically loads configurations from https://github.com/nf-core/configs when it runs, making multiple config profiles for various institutional clusters available at run time. For more information and to see if your system is available in these configs please see the nf-core/configs documentation.
Note that multiple profiles can be loaded, for example: -profile test,docker
- the order of arguments is important!
They are loaded in sequence, so later profiles can overwrite earlier profiles.
If -profile
is not specified, the pipeline will run locally and expect all software to be installed and available on the PATH
. This is not recommended, since it can lead to different results on different machines dependent on the computer enviroment.
test
- A profile with a complete configuration for automated testing
- Includes links to test data so needs no other parameters
docker
- A generic configuration profile to be used with Docker
singularity
- A generic configuration profile to be used with Singularity
podman
- A generic configuration profile to be used with Podman
shifter
- A generic configuration profile to be used with Shifter
charliecloud
- A generic configuration profile to be used with Charliecloud
apptainer
- A generic configuration profile to be used with Apptainer
conda
- A generic configuration profile to be used with Conda. Please only use Conda as a last resort i.e. when it’s not possible to run the pipeline with Docker, Singularity, Podman, Shifter, Charliecloud, or Apptainer.
-resume
Specify this when restarting a pipeline. Nextflow will use cached results from any pipeline steps where the inputs are the same, continuing from where it got to previously. For input to be considered the same, not only the names must be identical but the files’ contents as well. For more info about this parameter, see this blog post.
You can also supply a run name to resume a specific run: -resume [run-name]
. Use the nextflow log
command to show previous run names.
-c
Specify the path to a specific config file (this is a core Nextflow command). See the nf-core website documentation for more information.
Custom configuration
Resource requests
Whilst the default requirements set within the pipeline will hopefully work for most people and with most input data, you may find that you want to customise the compute resources that the pipeline requests. Each step in the pipeline has a default set of requirements for number of CPUs, memory and time. For most of the steps in the pipeline, if the job exits with any of the error codes specified here it will automatically be resubmitted with higher requests (2 x original, then 3 x original). If it still fails after the third attempt then the pipeline execution is stopped.
For example, if the nf-core/rnaseq pipeline is failing after multiple re-submissions of the STAR_ALIGN
process due to an exit code of 137
this would indicate that there is an out of memory issue:
For beginners
A first step to bypass this error, you could try to increase the amount of CPUs, memory, and time for the whole pipeline. Therefor you can try to increase the resource for the parameters --max_cpus
, --max_memory
, and --max_time
. Based on the error above, you have to increase the amount of memory. Therefore you can go to the parameter documentation of rnaseq and scroll down to the show hidden parameter
button to get the default value for --max_memory
. In this case 128GB, you than can try to run your pipeline again with --max_memory 200GB -resume
to skip all process, that were already calculated. If you can not increase the resource of the complete pipeline, you can try to adapt the resource for a single process as mentioned below.
Advanced option on process level
To bypass this error you would need to find exactly which resources are set by the STAR_ALIGN
process. The quickest way is to search for process STAR_ALIGN
in the nf-core/rnaseq Github repo.
We have standardised the structure of Nextflow DSL2 pipelines such that all module files will be present in the modules/
directory and so, based on the search results, the file we want is modules/nf-core/star/align/main.nf
.
If you click on the link to that file you will notice that there is a label
directive at the top of the module that is set to label process_high
.
The Nextflow label
directive allows us to organise workflow processes in separate groups which can be referenced in a configuration file to select and configure subset of processes having similar computing requirements.
The default values for the process_high
label are set in the pipeline’s base.config
which in this case is defined as 72GB.
Providing you haven’t set any other standard nf-core parameters to cap the maximum resources used by the pipeline then we can try and bypass the STAR_ALIGN
process failure by creating a custom config file that sets at least 72GB of memory, in this case increased to 100GB.
The custom config below can then be provided to the pipeline via the -c
parameter as highlighted in previous sections.
NB: We specify the full process name i.e.
NFCORE_RNASPLICE:RNASPLICE:ALIGN_STAR:STAR_ALIGN
in the config file because this takes priority over the short name (STAR_ALIGN
) and allows existing configuration using the full process name to be correctly overridden.If you get a warning suggesting that the process selector isn’t recognised check that the process name has been specified correctly.
Updating containers (advanced users)
The Nextflow DSL2 implementation of this pipeline uses one container per process which makes it much easier to maintain and update software dependencies. If for some reason you need to use a different version of a particular tool with the pipeline then you just need to identify the process
name and override the Nextflow container
definition for that process using the withName
declaration. For example, in the nf-core/viralrecon pipeline a tool called Pangolin has been used during the COVID-19 pandemic to assign lineages to SARS-CoV-2 genome sequenced samples. Given that the lineage assignments change quite frequently it doesn’t make sense to re-release the nf-core/viralrecon everytime a new version of Pangolin has been released. However, you can override the default container used by the pipeline by creating a custom config file and passing it as a command-line argument via -c custom.config
.
-
Check the default version used by the pipeline in the module file for Pangolin
-
Find the latest version of the Biocontainer available on Quay.io
-
Create the custom config accordingly:
-
For Docker:
-
For Singularity:
-
For Conda:
-
NB: If you wish to periodically update individual tool-specific results (e.g. Pangolin) generated by the pipeline then you must ensure to keep the
work/
directory otherwise the-resume
ability of the pipeline will be compromised and it will restart from scratch.
nf-core/configs
In most cases, you will only need to create a custom config as a one-off but if you and others within your organisation are likely to be running nf-core pipelines regularly and need to use the same settings regularly it may be a good idea to request that your custom config file is uploaded to the nf-core/configs
git repository. Before you do this please can you test that the config file works with your pipeline of choice using the -c
parameter. You can then create a pull request to the nf-core/configs
repository with the addition of your config file, associated documentation file (see examples in nf-core/configs/docs
), and amending nfcore_custom.config
to include your custom profile.
See the main Nextflow documentation for more information about creating your own configuration files.
If you have any questions or issues please send us a message on Slack on the #configs
channel.
Azure Resource Requests
To be used with the azurebatch
profile by specifying the -profile azurebatch
.
We recommend providing a compute params.vm_type
of Standard_D16_v3
VMs by default but these options can be changed if required.
Note that the choice of VM size depends on your quota and the overall workload during the analysis. For a thorough list, please refer the Azure Sizes for virtual machines in Azure.
Running in the background
Nextflow handles job submissions and supervises the running jobs. The Nextflow process must run until the pipeline is finished.
The Nextflow -bg
flag launches Nextflow in the background, detached from your terminal so that the workflow does not stop if you log out of your session. The logs are saved to a file.
Alternatively, you can use screen
/ tmux
or similar tool to create a detached session which you can log back into at a later time.
Some HPC setups also allow you to run nextflow within a cluster job submitted your job scheduler (from where it submits more jobs).
Nextflow memory requirements
In some cases, the Nextflow Java virtual machines can start to request a large amount of memory.
We recommend adding the following line to your environment to limit this (typically in ~/.bashrc
or ~./bash_profile
):