https://github.com/Gregor-Mendel-Institute/RKP2021-CMT3
Tip revision: 89d7e2ea78af1969bb161640baed09296ed2485f authored by Papareddy on 23 April 2021, 11:18:44 UTC
Update README.md
Update README.md
Tip revision: 89d7e2e
nextflow.config
/*
* -------------------------------------------------
* nf-core/chipseq Nextflow config file
* -------------------------------------------------
* Default config options for all environments.
*/
// Global default params, used in configs
params {
// Options: Generic
input = './design.csv'
single_end = false
seq_center = false
fragment_size = 200
fingerprint_bins = 500000
// Options: References
genome = false
save_reference = false
// Options: Trimming
clip_r1 = 0
clip_r2 = 0
three_prime_clip_r1 = 0
three_prime_clip_r2 = 0
trim_nextseq = 0
skip_trimming = false
save_trimmed = false
// Options: Alignments
bwa_min_score = false
keep_dups = false
keep_multi_map = false
save_align_intermeds = false
// Options: Peaks
narrow_peak = false
broad_cutoff = 0.1
macs_fdr = false
macs_pvalue = false
min_reps_consensus = 1
save_macs_pileup = false
skip_peak_qc = false
skip_peak_annotation = false
skip_consensus_peaks = false
// Options: Differential analysis
deseq2_vst = false
skip_diff_analysis = false
// Options: QC
skip_fastqc = false
skip_picard_metrics = false
skip_preseq = false
skip_plot_profile = false
skip_plot_fingerprint = false
skip_spp = false
skip_igv = false
skip_multiqc = false
// Options: Config
multiqc_config = false
bamtools_filter_pe_config = "$baseDir/assets/bamtools_filter_pe.json"
bamtools_filter_se_config = "$baseDir/assets/bamtools_filter_se.json"
// Options: Custom config
custom_config_version = 'master'
custom_config_base = "https://raw.githubusercontent.com/nf-core/configs/${params.custom_config_version}"
config_profile_description = false
config_profile_contact = false
config_profile_url = false
// Options: Other
help = false
outdir = './results'
publish_dir_mode = 'copy'
igenomes_base = 's3://ngi-igenomes/igenomes/'
igenomes_ignore = false
max_multiqc_email_size = 25.MB
tracedir = "${params.outdir}/pipeline_info"
email = false
email_on_fail = false
plaintext_email = false
monochrome_logs = false
name = false
hostnames = false
clusterOptions = false
// Defaults only, expecting to be overwritten
max_memory = 128.GB
max_cpus = 16
max_time = 240.h
}
// Container slug. Stable releases should specify release tag!
// Developmental code should specify :dev
process.container = 'nfcore/chipseq:1.2.1'
// Load base.config by default for all pipelines
includeConfig 'conf/base.config'
// Load nf-core custom profiles from different Institutions
try {
includeConfig "${params.custom_config_base}/nfcore_custom.config"
} catch (Exception e) {
System.err.println("WARNING: Could not load nf-core/config profiles: ${params.custom_config_base}/nfcore_custom.config")
}
profiles {
conda { process.conda = "$baseDir/environment.yml" }
debug { process.beforeScript = 'echo $HOSTNAME' }
docker {
docker.enabled = true
// Avoid this error:
// WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap.
// Testing this in nf-core after discussion here https://github.com/nf-core/tools/pull/351
// once this is established and works well, nextflow might implement this behavior as new default.
docker.runOptions = '-u \$(id -u):\$(id -g)'
}
singularity {
singularity.enabled = true
singularity.autoMounts = true
}
test { includeConfig 'conf/test.config' }
test_full { includeConfig 'conf/test_full.config' }
}
// Load igenomes.config if required
if (!params.igenomes_ignore) {
includeConfig 'conf/igenomes.config'
}
// Increase time available to build conda environment
conda { createTimeout = "60 min" }
// Export these variables to prevent local Python/R libraries from conflicting with those in the container
env {
PYTHONNOUSERSITE = 1
R_PROFILE_USER = "/.Rprofile"
R_ENVIRON_USER = "/.Renviron"
}
// Capture exit codes from upstream processes when piping
process.shell = ['/bin/bash', '-euo', 'pipefail']
timeline {
enabled = true
file = "${params.tracedir}/execution_timeline.html"
}
report {
enabled = true
file = "${params.tracedir}/execution_report.html"
}
trace {
enabled = true
file = "${params.tracedir}/execution_trace.txt"
}
dag {
enabled = true
file = "${params.tracedir}/pipeline_dag.svg"
}
manifest {
name = 'nf-core/chipseq'
author = 'Philip Ewels'
homePage = 'https://github.com/nf-core/chipseq'
description = 'ChIP-seq peak-calling and differential analysis pipeline.'
mainScript = 'main.nf'
nextflowVersion = '>=19.10.0'
version = '1.2.1'
}
// Function to ensure that resource requirements don't go beyond
// a maximum limit
def check_max(obj, type) {
if (type == 'memory') {
try {
if (obj.compareTo(params.max_memory as nextflow.util.MemoryUnit) == 1)
return params.max_memory as nextflow.util.MemoryUnit
else
return obj
} catch (all) {
println " ### ERROR ### Max memory '${params.max_memory}' is not valid! Using default value: $obj"
return obj
}
} else if (type == 'time') {
try {
if (obj.compareTo(params.max_time as nextflow.util.Duration) == 1)
return params.max_time as nextflow.util.Duration
else
return obj
} catch (all) {
println " ### ERROR ### Max time '${params.max_time}' is not valid! Using default value: $obj"
return obj
}
} else if (type == 'cpus') {
try {
return Math.min( obj, params.max_cpus as int )
} catch (all) {
println " ### ERROR ### Max cpus '${params.max_cpus}' is not valid! Using default value: $obj"
return obj
}
}
}