1
0
Fork 0
mirror of https://github.com/MillironX/nf-configs.git synced 2024-11-11 04:23:10 +00:00
nf-configs/conf/uppmax.config

93 lines
2.3 KiB
Text
Raw Normal View History

// Profile config names for nf-core/configs
2019-01-04 15:33:54 +00:00
params {
2019-01-07 13:25:06 +00:00
config_profile_description = 'Swedish UPPMAX cluster profile provided by nf-core/configs.'
2019-01-04 15:33:54 +00:00
config_profile_contact = 'Phil Ewels (@ewels)'
config_profile_url = 'https://www.uppmax.uu.se/'
project = null
clusterOptions = null
2021-03-26 14:22:57 +00:00
schema_ignore_params = "genomes,input_paths,cluster-options,clusterOptions,project"
2019-01-04 15:33:54 +00:00
}
singularity {
enabled = true
2021-10-07 14:05:03 +00:00
envWhitelist = 'SNIC_TMP'
}
def hostname = "r1"
try {
hostname = "sinfo --local -N -h | grep -F -v CLUSTER: | head -1 | cut -f1 -d' ' ".execute().text.trim()
} catch (java.io.IOException e) {
System.err.println("WARNING: Could not run sinfo to determine current cluster, defaulting to rackham")
}
// closure to create a suitable clusterOptions
def clusterOptionsCreator = { m ->
String base = "-A $params.project ${params.clusterOptions ?: ''}"
// Do not use -p node on irma or if a thin node/core is enough
if (m < 125.GB || hostname ==~ "i.*") {
return base
}
if (m < 250.GB) {
return base + " -p node -C mem256GB "
}
2021-04-12 17:34:28 +00:00
// Use mem1TB for remaining cases on rackham (no 512 Gbyte nodes)
if (hostname ==~ "r.*") {
return base + " -p node -C mem1TB "
}
2021-04-12 17:34:28 +00:00
if (m > 500.GB) {
// Special case for snowy very fat node (only remaining case that's above 500 GB)
return base + " -p veryfat "
}
// Should only be cases for mem512GB left (snowy and bianca)
return base + " -p node -C mem512GB "
}
process {
executor = 'slurm'
clusterOptions = { clusterOptionsCreator(task.memory) }
2021-10-07 14:05:03 +00:00
// Use node local storage for execution.
scratch = '$SNIC_TMP'
}
params {
2020-09-28 11:59:42 +00:00
save_reference = true
2019-01-07 13:25:06 +00:00
2021-04-12 17:21:58 +00:00
max_memory = 500.GB
max_cpus = 16
max_time = 240.h
// illumina iGenomes reference file paths on UPPMAX
2021-10-08 11:40:59 +00:00
igenomes_base = '/sw/data/igenomes/'
}
2021-04-12 17:32:21 +00:00
if (hostname ==~ "s[0-9][0-9]*") {
params.max_time = 700.h
2021-04-12 17:34:28 +00:00
params.max_memory = 3880.GB
2019-12-05 11:45:30 +00:00
}
2019-12-05 14:07:59 +00:00
if (hostname ==~ "i.*") {
params.max_memory = 250.GB
}
2019-12-05 14:18:01 +00:00
if (hostname ==~ "r.*") {
params.max_cpus = 20
2021-04-12 17:21:58 +00:00
params.max_memory = 970.GB
2019-12-05 14:18:01 +00:00
}
profiles {
devel {
params {
config_profile_description = 'Testing & development profile for UPPMAX, provided by nf-core/configs.'
// Max resources to be requested by a devel job
max_memory = 120.GB
max_time = 1.h
}
executor.queueSize = 1
process.queue = 'devel'
}
2019-12-06 09:31:56 +00:00
}