forked from nf-core/configs
-
Notifications
You must be signed in to change notification settings - Fork 0
/
utd_ganymede.config
68 lines (60 loc) · 1.79 KB
/
utd_ganymede.config
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
//Profile config names for nf-core/configs
params {
config_profile_description = 'University of Texas at Dallas HPC cluster profile provided by nf-core/configs'
config_profile_contact = 'Edmund Miller'
config_profile_contact_github = '@edmundmiller'
config_profile_contact_email = '[email protected]'
config_profile_url = 'https://docs.circ.utdallas.edu/user-guide/systems/ganymede.html'
}
env {
SINGULARITY_CACHEDIR="/home/$USER/scratch/singularity"
}
singularity {
enabled = true
envWhitelist='SINGULARITY_BINDPATH,LD_LIBRARY_PATH'
autoMounts = true
cacheDir = "/home/$USER/scratch/singularity"
}
def membership = "groups".execute().text
def select_queue = { memory, cpu ->
if (memory <= 28.GB && cpu <= 16 && membership.contains('genomics')) {
return 'genomics,normal'
}
if (memory > 28.GB && memory <= 125.GB && cpu <= 12 && membership.contains('kim')) {
return 'Kim,128s'
}
if (memory > 28.GB && memory <= 125.GB && cpu <= 16) {
return '128s'
}
if (memory <= 250.GB && cpu <= 28) {
return '256i,256h'
}
}
// Submit up to 100 concurrent jobs
// pollInterval and queueStatInterval of every 5 minutes
// submitRateLimit of 20 per minute
executor {
queueSize = 100
queueStatInterval = '2 min'
submitRateLimit = '20 min'
jobName = { "${task.process.split(':').last()}" }
}
process {
resourceLimits = [
memory: 250.GB,
cpus: 28,
time: 96.h
]
beforeScript = 'module load singularity/3.2.1'
executor = 'slurm'
queue = { select_queue(task.memory, task.cpu) }
withLabel:process_medium {
cpus = { 16 * task.attempt }
memory = { 30.GB * task.attempt }
}
}
params {
max_memory = 250.GB
max_cpus = 28
max_time = 96.h
}