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.

--input '[path to samplesheet file]'

The samplesheet has to be a comma-seperated file with at least 3 columns, and a header row as shown in the example below.

sample,fastq_1,fastq_2,strandedness,condition
CONTROL_REP1,AEG588A1_S1_L002_R1_001.fastq.gz,AEG588A1_S1_L002_R2_001.fastq.gz,forward,control
CONTROL_REP2,AEG588A2_S2_L002_R1_001.fastq.gz,AEG588A2_S2_L002_R2_001.fastq.gz,forward,control
CONTROL_REP3,AEG588A3_S3_L002_R1_001.fastq.gz,AEG588A3_S3_L002_R2_001.fastq.gz,forward,control

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.

ColumnDescription
sampleCustom 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_1Full path to FastQ file for Illumina short reads 1. File has to be gzipped and have the extension “.fastq.gz” or “.fq.gz”.
fastq_2Full path to FastQ file for Illumina short reads 2. File has to be gzipped and have the extension “.fastq.gz” or “.fq.gz”.
strandednessSample strand-specificity. Must be one of unstranded, forward or reverse.
conditionThe name of the condition a sample belongs to (e.g. ‘control’, or ‘treatment’) - these labels will be used for downstream analysis.
genome_bamFull path to aligned BAM file, derived from splicing aware mapper (STAR, HiSat, etc). File has to be in “.bam” format.
transcriptome_bamFull path to aligned transcriptome file, derived from splicing aware mapper (STAR, HiSat, etc). File has to be in “.bam” format.
salmon_resultsFull 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.

--source '[source type]'

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.

sample,fastq_1,fastq_2,strandedness,condition
CONTROL_REP1,AEG588A1_S1_L002_R1_001.fastq.gz,AEG588A1_S1_L002_R2_001.fastq.gz,forward,control
CONTROL_REP2,AEG588A2_S2_L002_R1_001.fastq.gz,AEG588A2_S2_L002_R2_001.fastq.gz,forward,control
CONTROL_REP3,AEG588A3_S3_L002_R1_001.fastq.gz,AEG588A3_S3_L002_R2_001.fastq.gz,forward,control
TREATMENT_REP1,AEG588A4_S4_L003_R1_001.fastq.gz,,reverse,treatment
TREATMENT_REP2,AEG588A5_S5_L003_R1_001.fastq.gz,,reverse,treatment
TREATMENT_REP3,AEG588A6_S6_L003_R1_001.fastq.gz,,reverse,treatment
TREATMENT_REP3,AEG588A6_S6_L004_R1_001.fastq.gz,,reverse,treatment

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.

sample,condition,genome_bam
CONTROL_REP1,control,AEG588A1.Aligned.out.bam
CONTROL_REP2,control,AEG588A2.Aligned.out.bam
CONTROL_REP3,control,AEG588A3.Aligned.out.bam
TREATMENT_REP1,treatment,AEG588A4.Aligned.out.bam
TREATMENT_REP2,treatment,AEG588A5.Aligned.out.bam
TREATMENT_REP3,treatment,AEG588A6.Aligned.out.bam

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.

sample,condition,transcriptome_bam
CONTROL_REP1,control,AEG588A1.Aligned.toTranscriptome.out.bam
CONTROL_REP2,control,AEG588A2.Aligned.toTranscriptome.out.bam
CONTROL_REP3,control,AEG588A3.Aligned.toTranscriptome.out.bam
TREATMENT_REP1,treatment,AEG588A4.Aligned.toTranscriptome.out.bam
TREATMENT_REP2,treatment,AEG588A5.Aligned.toTranscriptome.out.bam
TREATMENT_REP3,treatment,AEG588A6.Aligned.toTranscriptome.out.bam

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.

sample,condition,salmon
CONTROL_REP1,control,AEG588A1.tar.gz
CONTROL_REP2,control,AEG588A2.tar.gz
CONTROL_REP3,control,AEG588A3.tar.gz
TREATMENT_REP1,treatment,AEG588A4.tar.gz
TREATMENT_REP2,treatment,AEG588A5.tar.gz
TREATMENT_REP3,treatment,AEG588A6.tar.gz

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.

--contrasts '[path to contrastsheet file]'

The contrastsheet has to be a comma-separated file with 3 columns, and a header row as shown in the examples below.

contrast,treatment,control
TREATMENT_CONTROL,TREATMENT,CONTROL

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.

ColumnDescription
contrastAn arbitrary identifier, will be used to name contrast-wise output files.
treatmentThe treatment/target level for the comparison.
controlThe 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 to true 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:

nextflow run nf-core/rnasplice --input samplesheet.csv --contrasts contrastsheet.csv --outdir <OUTDIR> --genome GRCh37 -profile docker

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:

work                # Directory containing the nextflow working files
<OUTDIR>            # Finished results in specified location (defined with --outdir)
.nextflow_log       # Log file from Nextflow
# Other nextflow hidden files, eg. history of pipeline runs and old logs.

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>.

Warning

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:

nextflow run nf-core/rnasplice -profile docker -params-file params.yaml

with params.yaml containing:

input: './samplesheet.csv'
contrasts: './contrastsheet.csv'
outdir: './results/'
genome: 'GRCh37'
<...>

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:

nextflow pull nf-core/rnasplice

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.

Tip

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

Note

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.

Info

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:

[62/149eb0] NOTE: Process `NFCORE_RNASPLICE:RNASPLICE:ALIGN_STAR:STAR_ALIGN (WT_REP1)` terminated with an error exit status (137) -- Execution is retried (1)
Error executing process > 'NFCORE_RNASPLICE:RNASPLICE:ALIGN_STAR:STAR_ALIGN (WT_REP1)'
 
Caused by:
    Process `NFCORE_RNASPLICE:RNASPLICE:ALIGN_STAR:STAR_ALIGN (WT_REP1)` terminated with an error exit status (137)
 
Command executed:
    STAR \
        --genomeDir star \
        --readFilesIn WT_REP1_trimmed.fq.gz  \
        --runThreadN 2 \
        --outFileNamePrefix WT_REP1. \
        <TRUNCATED>
 
Command exit status:
    137
 
Command output:
    (empty)
 
Command error:
    .command.sh: line 9:  30 Killed    STAR --genomeDir star --readFilesIn WT_REP1_trimmed.fq.gz --runThreadN 2 --outFileNamePrefix WT_REP1. <TRUNCATED>
Work dir:
    /home/pipelinetest/work/9d/172ca5881234073e8d76f2a19c88fb
 
Tip: you can replicate the issue by changing to the process work dir and entering the command `bash .command.run`

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.

process {
    withName: 'NFCORE_RNASPLICE:RNASPLICE:ALIGN_STAR:STAR_ALIGN' {
        memory = 100.GB
    }
}

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.

  1. Check the default version used by the pipeline in the module file for Pangolin

  2. Find the latest version of the Biocontainer available on Quay.io

  3. Create the custom config accordingly:

    • For Docker:

      process {
          withName: PANGOLIN {
              container = 'quay.io/biocontainers/pangolin:3.0.5--pyhdfd78af_0'
          }
      }
    • For Singularity:

      process {
          withName: PANGOLIN {
              container = 'https://depot.galaxyproject.org/singularity/pangolin:3.0.5--pyhdfd78af_0'
          }
      }
    • For Conda:

      process {
          withName: PANGOLIN {
              conda = 'bioconda::pangolin=3.0.5'
          }
      }

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):

NXF_OPTS='-Xms1g -Xmx4g'