nf-core/configs: Engaging Configuration
All nf-core pipelines have been successfully configured for use on the MIT Engaging Cluster.
To use, run the pipeline with -profile engaging. This will download and launch the engaging.config which has been pre-configured with a setup suitable for the Engaging 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.
Below are non-mandatory information e.g. on modules to load etc
Before running the pipeline you will need to install Nextflow and load Singularity using the environment module system on Engaging Cluster. You can do this by issuing the commands below:
## Load Java and Singularity environment modules
module purge
module load jdk/18.0.1.1
module load singularity/3.7.0
 
# Download Nextflow
curl -s https://get.nextflow.io | bashNB: You will need an account to use the HPC cluster on Engaging in order to run the pipeline. If in doubt contact IT. NB: Nextflow will need to submit the jobs via the job scheduler to the HPC cluster and as such the commands above will have to be executed on one of the login nodes. If in doubt contact IT.
Config file
// Nextflow config for running on the MIT Engaging HPC cluster
params {
    config_profile_description = 'MIT Engaging HPC cluster profile.'
    config_profile_contact     = 'Charlie Whittaker (@bumproo)'
    config_profile_url         = "https://engaging-web.mit.edu/eofe-wiki/"
}
 
singularity {
    enabled    = true
    autoMounts = true
}
 
process {
    resourceLimits = [
        memory: 128.GB,
        cpus: 16,
        time: 10.h
    ]
    executor       = 'slurm'
    clusterOptions = '-p mit_normal'
}
 
executor {
    queueSize = 8
}
 
params {
    max_memory = 128.GB
    max_cpus   = 16
    max_time   = 10.h
}
 Pipeline configs
params {
    config_profile_description = 'MIT Engaging HPC cluster profile.'
    config_profile_contact     = 'Phil Palmer (@PhilPalmer)'
}
 
process {
    // Launch intensive assembly processes on newnodes partition with max resources
    withName: SPADES {
        clusterOptions = '-p newnodes'
        cpus           = 20
        memory         = 250.GB
        time           = 12.h
        errorStrategy  = { task.exitStatus in [143, 137, 1] ? 'retry' : 'finish' }
        maxRetries     = 3
    }
    withName: MEGAHIT {
        clusterOptions = '-p newnodes'
        cpus           = 20
        memory         = 250.GB
        time           = 12.h
        errorStrategy  = { task.exitStatus in [143, 137, 104, 134, 139, 250] ? 'retry' : 'finish' }
        maxRetries     = 3
    }
}