Rosalind Configuration

All nf-core pipelines have been successfully configured for use on the Rosalind CLuster at Kings College London. To use, run the pipeline with -profile rosalind. This will download and launch the rosalind.config which has been pre-configured with a setup suitable for the rosalind cluster. Using this profile, a docker image containing all of the required software will be downloaded, and converted to a Singularity image before execution of the pipeline.

Using Nextflow on Rosalind

Before running the pipeline you will need to configure Nextflow and Singularity. There is no Nextflow module on Rosalind at this time. This can be done with the following commands:

## Load Singularity environment modules - these commands can be placed in your ~/.bashrc also
module load apps/openjdk
module load apps/singularity

## Download Nextflow-all
wget https://github.com/nextflow-io/nextflow/releases/download/v21.04.3/nextflow-21.04.3-all
chmod a+x nextflow-21.04.3-all
mv nextflow-21.04.3-all ~/bin/nextflow

By default, the shared partition is used for job submission. Other partitions can be specified using the --partition <PARTITION NAME> argument to the run.

Additional information

The default shared partition resource limits are defined as ten percent of the total available to the cluster at any one point in time. The limitations defined by this configuration are conservative and are projected to be increased as greater computational resources are introduced in the near future.

Config file

See config file on GitHub

params {
    config_profile_description = 'Kings College London Rosalind HPC'
    config_profile_contact     = 'Theo Portlock'
    config_profile_url         = 'https://www.rosalind.kcl.ac.uk/'
}

singularity {
    enabled        = true
    autoMounts     = true
    docker.enabled = false
}

params {
    max_memory                   = 64.GB
    max_cpus                     = 16
    max_time                     = 24.h
    partition                    = 'shared'
    schema_ignore_params         = 'partition,genomes,modules'
    validationSchemaIgnoreParams = "partition,genomes,modules,schema_ignore_params"
}

process {
    resourceLimits = [
        memory: 64.GB,
        cpus: 16,
        time: 24.h
    ]
    executor       = 'slurm'
    maxRetries     = 3
    clusterOptions = { "--partition=${params.partition}" }
}

executor {
    submitRateLimit = '1 sec'
}