Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add optional merging and trimming #142

Merged
merged 56 commits into from
Mar 4, 2019
Merged
Show file tree
Hide file tree
Changes from 11 commits
Commits
Show all changes
56 commits
Select commit Hold shift + click to select a range
eb59405
Extra clarifications for indices, FastP and general cleanup
jfy133 Feb 1, 2019
df6305f
Merge pull request #136 from nf-core/help_message_improvements
apeltzer Feb 1, 2019
f43f4b0
Further clarification on `--max-cpus`
jfy133 Feb 2, 2019
45ce547
Update docs/usage.md
apeltzer Feb 2, 2019
e039f28
Merge pull request #139 from nf-core/docs_update
apeltzer Feb 2, 2019
91d05cb
add noCollase option
maxibor Feb 11, 2019
758fb7f
fix nf-PE read index
maxibor Feb 11, 2019
e2aaba0
update doc with noCollapse
maxibor Feb 11, 2019
bdd56dc
merge master to dev
maxibor Feb 11, 2019
55743dd
main.nf to dev
maxibor Feb 11, 2019
8ec9d67
fix funky prefix
maxibor Feb 11, 2019
6d864e1
Update docs/usage.md
apeltzer Feb 11, 2019
f3a6ff7
Update docs/usage.md
apeltzer Feb 12, 2019
0e03a00
skip trimming and collapsing
maxibor Feb 12, 2019
757e930
update test
maxibor Feb 12, 2019
949fd28
Address issue with picard memory
apeltzer Feb 19, 2019
435812b
Merge pull request #145 from apeltzer/fix-picard
apeltzer Feb 19, 2019
b311d61
Use CSI indices wherever possible
apeltzer Feb 21, 2019
a1a69a7
Merge remote-tracking branch 'upstream/dev' into fix-samtools-idx
apeltzer Feb 21, 2019
9eb36c7
Add proper changelog
apeltzer Feb 21, 2019
8d26b33
Added a contributor section to README
apeltzer Feb 21, 2019
8e29eff
Update README.md with instructions for test data
evanfloden Feb 21, 2019
8f3c151
Merge pull request #148 from evanfloden/patch-1
apeltzer Feb 21, 2019
abf4642
Add docs on this
apeltzer Feb 21, 2019
8a6dccb
Update new parameter `large_ref`
apeltzer Feb 25, 2019
b6f65b1
Fixing indices hopefully
apeltzer Feb 25, 2019
f9ac1d4
Fixing indexing
apeltzer Feb 25, 2019
7405c8e
Fix for post-dup steps
apeltzer Feb 25, 2019
7e4035d
Nicer changelog [skip ci]
apeltzer Feb 25, 2019
76e0cbd
Its unpublished stuff [skip ci]
apeltzer Feb 25, 2019
a2364b4
Merge pull request #3 from nf-core/dev
jfy133 Feb 25, 2019
e971cac
Made polyG param clearer what it is
jfy133 Feb 25, 2019
0feeb19
Update CHANGELOG.md
jfy133 Feb 25, 2019
29306df
Updated ploy G trim flag
jfy133 Feb 25, 2019
028f7ea
Merge pull request #5 from jfy133/polyg-name-improvements
jfy133 Feb 25, 2019
bc02be2
Update CHANGELOG.md
jfy133 Feb 25, 2019
ffa0085
Merge pull request #4 from jfy133/polyg-name-improvement
jfy133 Feb 25, 2019
7836ab8
Update CHANGELOG.md
jfy133 Feb 25, 2019
6d13545
Added fastP position to MultiQC config
jfy133 Feb 25, 2019
ee3c44f
Merge pull request #147 from apeltzer/fix-samtools-idx
apeltzer Feb 26, 2019
0fb1481
Merge branch 'dev' into fix-post-dedup-steps
apeltzer Feb 26, 2019
fabd1a3
Should fix the remaining issues
apeltzer Feb 26, 2019
24ea4b7
Merge branch 'fix-post-dedup-steps' of https://github.com/apeltzer/ea…
apeltzer Feb 26, 2019
c69261d
Address issues with qualimap / multiqc / multiple samples and reporting
apeltzer Feb 26, 2019
e85b58f
Merge pull request #151 from apeltzer/fix-post-dedup-steps
apeltzer Feb 27, 2019
16fedae
Merge branch 'dev' into dev
apeltzer Feb 27, 2019
71f0329
Merge pull request #152 from jfy133/dev
apeltzer Feb 27, 2019
817b9e0
Adding in publishing dedup log files as well
apeltzer Mar 1, 2019
5a255fd
Merge pull request #157 from apeltzer/publish_dedup
apeltzer Mar 2, 2019
c0251cb
Merge branch 'dev' into dev
apeltzer Mar 4, 2019
3320464
move size out of the if clause
apeltzer Mar 4, 2019
def1b35
match skip_* pattern
maxibor Mar 4, 2019
2bef839
update travis test
maxibor Mar 4, 2019
e62b503
local executor for skipping AR process
maxibor Mar 4, 2019
e807c58
initialize skip_adapterremoval
maxibor Mar 4, 2019
01d056c
fix bam test
maxibor Mar 4, 2019
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 6 additions & 0 deletions .travis.yml
Original file line number Diff line number Diff line change
Expand Up @@ -40,14 +40,20 @@ script:
- nextflow run ${TRAVIS_BUILD_DIR} -profile test,docker --pairedEnd --saveReference
# Run the basic pipeline with single end data (pretending its single end actually)
- nextflow run ${TRAVIS_BUILD_DIR} -profile test,docker --singleEnd --bwa_index results/reference_genome/bwa_index/bwa_index/
# Run the basic pipeline with paired end data
- nextflow run ${TRAVIS_BUILD_DIR} -profile test,docker --pairedEnd --noCollapse --saveReference
# Run the same pipeline testing optional step: fastp, complexity
- nextflow run ${TRAVIS_BUILD_DIR} -profile test,docker --pairedEnd --complexity_filter --bwa_index results/reference_genome/bwa_index/bwa_index/
# Test BAM Trimming
- nextflow run ${TRAVIS_BUILD_DIR} -profile test,docker --pairedEnd --trim_bam --bwa_index results/reference_genome/bwa_index/bwa_index/
# Test running with CircularMapper
- nextflow run ${TRAVIS_BUILD_DIR} -profile test,docker --pairedEnd --circularmapper --circulartarget 'NC_007596.2'
# Test running with CircularMapper on paired end without collapsing
- nextflow run ${TRAVIS_BUILD_DIR} -profile test,docker --pairedEnd --noCollapse --circularmapper --circulartarget 'NC_007596.2'
# Test running with BWA Mem
- nextflow run ${TRAVIS_BUILD_DIR} -profile test,docker --pairedEnd --bwamem --bwa_index results/reference_genome/bwa_index/bwa_index/
# Test running with BWA Mem on paired end without collapsing
- nextflow run ${TRAVIS_BUILD_DIR} -profile test,docker --pairedEnd --noCollapse --bwamem --bwa_index results/reference_genome/bwa_index/bwa_index/
# Test with zipped reference input
- nextflow run ${TRAVIS_BUILD_DIR} -profile test,docker --pairedEnd --fasta 'https://raw.githubusercontent.com/nf-core/test-datasets/eager2/reference/Test.fasta.gz'
# Run the basic pipeline with the bam input profile
Expand Down
10 changes: 9 additions & 1 deletion docs/usage.md
Original file line number Diff line number Diff line change
Expand Up @@ -162,6 +162,14 @@ A normal glob pattern, enclosed in quotation marks, can then be used for `--read
--pairedEnd --reads '*.fastq'
```

### `--noCollapse`
If you have paired-end data, but you don't want to merge them, add the commind line argument `--noCollapse`.
maxibor marked this conversation as resolved.
Show resolved Hide resolved

For example
```bash
--pairedEnd --noCollapse '*.fastq'
maxibor marked this conversation as resolved.
Show resolved Hide resolved
```

### `--fasta`
If you prefer, you can specify the full path to your reference genome when you run the pipeline:

Expand Down Expand Up @@ -237,7 +245,7 @@ Use to set a top-limit for the default time requirement for each process.
Should be a string in the format integer-unit. eg. `--max_time '2.h'`. If not specified, will be taken from the configuration in the `-profile` flag.

### `--max_cpus`
Use to set a top-limit for the default CPU requirement for each process.
Use to set a top-limit for the default CPU requirement for each **process**. This is not the maximum number of CPUs that can be used for the whole pipeline, but the maximum number of CPUs each program can use for each program submission (known as a process). Do not set this higher than what is available on your workstation or computing node can provide. If you're unsure, ask your local IT administrator for details on compute node capabilities!
Should be a string in the format integer-unit. eg. `--max_cpus 1`. If not specified, will be taken from the configuration in the `-profile` flag.

### `--email`
Expand Down
121 changes: 84 additions & 37 deletions main.nf
Original file line number Diff line number Diff line change
Expand Up @@ -26,21 +26,22 @@ def helpMessage() {

Mandatory arguments:
--reads Path to input data (must be surrounded with quotes)
-profile Hardware config to use (e.g. standard, docker, singularity, conda, aws). Ask your system admin if unsure, or check documentatoin.
-profile Institution or personal hardware config to use (e.g. standard, docker, singularity, conda, aws). Ask your system admin if unsure, or check documentation.
--singleEnd Specifies that the input is single end reads (required if not pairedEnd)
--pairedEnd Specifies that the input is paired end reads (required if not singleend)
--pairedEnd Specifies that the input is paired end reads (required if not singleEnd)
--noCollapse Specifies to avoid merging Forward and Reverse reads together. (Only for pairedEnd samples)
--bam Specifies that the input is in BAM format
--fasta Path to Fasta reference (required if not iGenome reference)
--genome Name of iGenomes reference (required if not fasta reference)

Input Data Additional Options:
--snpcapture Runs in SNPCapture mode (specify a BED file if you do this!)

References If not specified in the configuration file or you wish to overwrite any of the references.
--bwa_index Path to BWA index
References If not specified in the configuration file, or you wish to overwrite any of the references.
--bwa_index Path to directory containing BWA index files
--bedfile Path to BED file for SNPCapture methods
--seq_dict Path to sequence dictionary file
--fasta_index Path to FastA index
--seq_dict Path to picard sequence dictionary file (typically ending in '.dict')
--fasta_index Path to samtools FASTA index (typically ending in '.fai')
--saveReference Saves reference genome indices for later reusage

Skipping Skip any of the mentioned steps
Expand All @@ -50,8 +51,8 @@ def helpMessage() {
--skip_deduplication

Complexity Filtering
--complexity_filtering Run complexity filtering on FastQ files
--complexity_filter_poly_g_min Specify poly-g min filter (default: 10) for filtering
--complexity_filtering Run poly-G removal on FASTQ files
--complexity_filter_poly_g_min Specify length of poly-g min for clipping to be performed (default: 10)

Clipping / Merging
--clip_forward_adaptor Specify adapter sequence to be clipped off (forward)
Expand All @@ -61,23 +62,23 @@ def helpMessage() {
--min_adap_overlap Specify minimum adapter overlap

BWA Mapping
--bwaalnn Specify the -n parameter for BWA aln
--bwaalnn Specify the -n parameter for BWA aln.
--bwaalnk Specify the -k parameter for BWA aln
--bwaalnl Specify the -l parameter for BWA aln

CircularMapper
--circularmapper Turn on CircularMapper (CM)
--circularextension Specify the number of bases to extend
--circularextension Specify the number of bases to extend reference by
--circulartarget Specify the target chromosome for CM
--circularfilter Specify to filter off-target reads

BWA Mem Mapping
--bwamem Turn on BWA Mem instead of CM/BWA aln for mapping
--bwamem Turn on BWA Mem instead of BWA aln for mapping

BAM Filtering
--bam_discard_unmapped Discards unmapped reads in either FASTQ or BAM format, depending on choice.
--bam_unmapped_type Defines whether to discard all unmapped reads, keep only bam and/or keep only fastq format (options: discard, bam, fastq, both).
--bam_mapping_quality_threshold Minimum mapping quality for reads filter, default 0.
--bam_discard_unmapped Discards unmapped reads in either FASTQ or BAM format, depending on choice (see --bam_unmapped_type).
--bam_unmapped_type Defines whether to discard all unmapped reads, keep only bam and/or keep only fastq format (options: discard, bam, fastq, both).

DeDuplication
--dedupper Deduplication method to use (options: dedup, markduplicates). Default: dedup
Expand All @@ -101,10 +102,6 @@ def helpMessage() {
--bamutils_clip_left / --bamutils_clip_right Specify the number of bases to clip off reads
--bamutils_softclip Use softclip instead of hard masking


For a full list and more information of available parameters, consider the documentation.


Other options:
--outdir The output directory where the results will be saved
--email Set this parameter to your e-mail address to get a summary e-mail with details of the run sent to you when the workflow exits
Expand All @@ -114,6 +111,9 @@ def helpMessage() {
--max_time Time limit for each step of the pipeline. Should be in form e.g. --max_memory '2.h'
--max_cpus Maximum number of CPUs to use for each step of the pipleine. Should be in form e.g. --max_cpus 1

For a full list and more information of available parameters, consider the documentation (https://github.com/nf-core/eager/).


""".stripIndent()
}
/*
Expand All @@ -131,6 +131,7 @@ if (params.help){
params.name = false
params.singleEnd = false
params.pairedEnd = false
params.noCollapse = false
params.genome = "Custom"
params.snpcapture = false
params.bedfile = ''
Expand Down Expand Up @@ -265,6 +266,11 @@ if( params.singleEnd || params.pairedEnd || params.bam){
exit 1, "Please specify either --singleEnd, --pairedEnd to execute the pipeline on FastQ files and --bam for previously processed BAM files!"
}

//Validate that noCollase is only set to True for pairedEnd reads!
if (params.noCollapse && params.singleEnd){
exit 1, "--noCollapse can only be set for pairedEnd samples!"
}


//AWSBatch sanity checking
if(workflow.profile == 'awsbatch'){
Expand Down Expand Up @@ -349,6 +355,7 @@ summary['Reads'] = params.reads
summary['Fasta Ref'] = params.fasta
if(params.bwa_index) summary['BWA Index'] = params.bwa_index
summary['Data Type'] = params.singleEnd ? 'Single-End' : 'Paired-End'
summary['Collapse'] = !params.noCollapse ? 'Yes' : 'No'
summary['Max Memory'] = params.max_memory
summary['Max CPUs'] = params.max_cpus
summary['Max Time'] = params.max_time
Expand Down Expand Up @@ -508,7 +515,7 @@ process convertBam {

output:
set val("${base}"), file("*.fastq.gz") into (ch_read_files_converted_fastqc, ch_read_files_converted_fastp)
file("*.fastq.gz") into (ch_read_files_converted_mapping_bwa, ch_read_files_converted_mapping_cm, ch_read_files_converted_mapping_bwamem)
set val("${base}"), file("*.fastq.gz") into (ch_read_files_converted_mapping_bwa, ch_read_files_converted_mapping_cm, ch_read_files_converted_mapping_bwamem)

script:
base = "${bam.baseName}"
Expand Down Expand Up @@ -594,19 +601,25 @@ process adapter_removal {
//Readprefixing only required for PE data with merging
fixprefix = (params.singleEnd) ? "" : "AdapterRemovalFixPrefix ${prefix}.combined.fq.gz ${prefix}.combined.prefixed.fq.gz"

if( !params.singleEnd ){
if( !params.singleEnd && !params.noCollapse){
"""
AdapterRemoval --file1 ${reads[0]} --file2 ${reads[1]} --basename ${prefix} --gzip --threads ${task.cpus} --trimns --trimqualities --adapter1 ${params.clip_forward_adaptor} --adapter2 ${params.clip_reverse_adaptor} --minlength ${params.clip_readlength} --minquality ${params.clip_min_read_quality} --minadapteroverlap ${params.min_adap_overlap} --collapse
AdapterRemoval --file1 ${reads[0]} --file2 ${reads[1]} --basename ${name} --gzip --threads ${task.cpus} --trimns --trimqualities --adapter1 ${params.clip_forward_adaptor} --adapter2 ${params.clip_reverse_adaptor} --minlength ${params.clip_readlength} --minquality ${params.clip_min_read_quality} --minadapteroverlap ${params.min_adap_overlap} --collapse
maxibor marked this conversation as resolved.
Show resolved Hide resolved
#Combine files
zcat *.collapsed.gz *.collapsed.truncated.gz *.singleton.truncated.gz *.pair1.truncated.gz *.pair2.truncated.gz | gzip > ${prefix}.combined.fq.gz
${fixprefix}
rm ${prefix}.combined.fq.gz
zcat *.collapsed.gz *.collapsed.truncated.gz *.singleton.truncated.gz *.pair1.truncated.gz *.pair2.truncated.gz | gzip > ${name}.combined.fq.gz
"""
} else {
} else if (!params.singleEnd && params.noCollapse) {
"""
AdapterRemoval --file1 ${reads[0]} --file2 ${reads[1]} --basename ${name} --gzip --threads ${task.cpus} --trimns --trimqualities --adapter1 ${params.clip_forward_adaptor} --adapter2 ${params.clip_reverse_adaptor} --minlength ${params.clip_readlength} --minquality ${params.clip_min_read_quality} --minadapteroverlap ${params.min_adap_overlap}
maxibor marked this conversation as resolved.
Show resolved Hide resolved
#Rename files
mv ${name}.pair1.truncated.gz ${name}.pair1.combined.fq.gz
mv ${name}.pair2.truncated.gz ${name}.pair2.combined.fq.gz
"""
AdapterRemoval --file1 ${reads[0]} --basename ${prefix} --gzip --threads ${task.cpus} --trimns --trimqualities --adapter1 ${params.clip_forward_adaptor} --minlength ${params.clip_readlength} --minquality ${params.clip_min_read_quality}
}
else {
"""
AdapterRemoval --file1 ${reads[0]} --basename ${name} --gzip --threads ${task.cpus} --trimns --trimqualities --adapter1 ${params.clip_forward_adaptor} --minlength ${params.clip_readlength} --minquality ${params.clip_min_read_quality}
# Pseudo-Combine
mv *.truncated.gz ${prefix}.combined.fq.gz
mv *.truncated.gz ${name}.combined.fq.gz
maxibor marked this conversation as resolved.
Show resolved Hide resolved
"""
}
}
Expand All @@ -615,7 +628,7 @@ process adapter_removal {
* STEP 2.1 - FastQC after clipping/merging (if applied!)
*/
process fastqc_after_clipping {
tag "${reads[0].baseName}"
tag "${prefix}"
publishDir "${params.outdir}/FastQC/after_clipping", mode: 'copy',
saveAs: {filename -> filename.indexOf(".zip") > 0 ? "zips/$filename" : "$filename"}

Expand All @@ -628,6 +641,7 @@ process fastqc_after_clipping {
file "*_fastqc.{zip,html}" optional true into ch_fastqc_after_clipping

script:
prefix = reads[0].toString().tokenize('.')[0]
"""
fastqc -q $reads
"""
Expand All @@ -654,13 +668,24 @@ process bwa {


script:
prefix = reads[0].toString() - ~/(_R1)?(\.combined\.)?(prefixed)?(_trimmed)?(_val_1)?(\.fq)?(\.fastq)?(\.gz)?$/
fasta = "${index}/*.fasta"
fasta = "${index}/*.fasta"
if (!params.singleEnd && params.noCollapse){
prefix = reads[0].toString().tokenize('.')[0]
"""
bwa aln -t ${task.cpus} $fasta ${reads[0]} -n ${params.bwaalnn} -l ${params.bwaalnl} -k ${params.bwaalnk} -f ${prefix}.r1.sai
bwa aln -t ${task.cpus} $fasta ${reads[1]} -n ${params.bwaalnn} -l ${params.bwaalnl} -k ${params.bwaalnk} -f ${prefix}.r2.sai
bwa sampe -r "@RG\\tID:ILLUMINA-${prefix}\\tSM:${prefix}\\tPL:illumina" $fasta ${prefix}.r1.sai ${prefix}.r2.sai ${reads[0]} ${reads[1]} | samtools sort -@ ${task.cpus} -O bam - > ${prefix}.sorted.bam
samtools index ${prefix}.sorted.bam
"""
} else {
prefix = reads[0].toString().tokenize('.')[0]
"""
bwa aln -t ${task.cpus} $fasta $reads -n ${params.bwaalnn} -l ${params.bwaalnl} -k ${params.bwaalnk} -f "${reads.baseName}.sai"
bwa samse -r "@RG\\tID:ILLUMINA-${prefix}\\tSM:${prefix}\\tPL:illumina" $fasta "${reads.baseName}".sai $reads | samtools sort -@ ${task.cpus} -O bam - > "${prefix}".sorted.bam
samtools index "${prefix}".sorted.bam
bwa aln -t ${task.cpus} $fasta $reads -n ${params.bwaalnn} -l ${params.bwaalnl} -k ${params.bwaalnk} -f ${prefix}.sai
bwa samse -r "@RG\\tID:ILLUMINA-${prefix}\\tSM:${prefix}\\tPL:illumina" $fasta ${prefix}.sai $reads | samtools sort -@ ${task.cpus} -O bam - > "${prefix}".sorted.bam
samtools index ${prefix}.sorted.bam
"""
}

}

process circulargenerator{
Expand Down Expand Up @@ -708,16 +733,30 @@ process circularmapper{

script:
filter = "${params.circularfilter}" ? '' : '-f true -x false'
prefix = reads[0].toString() - ~/(_R1)?(\.combined\.)?(prefixed)?(_trimmed)?(_val_1)?(\.fq)?(\.fastq)?(\.gz)?$/

fasta = "${index}/*_*.fasta"

if (!params.singleEnd && params.noCollapse){
prefix = reads[0].toString().tokenize('.')[0]
"""
bwa aln -t ${task.cpus} $fasta ${reads[0]} -n ${params.bwaalnn} -l ${params.bwaalnl} -k ${params.bwaalnk} -f ${prefix}.r1.sai
bwa aln -t ${task.cpus} $fasta ${reads[1]} -n ${params.bwaalnn} -l ${params.bwaalnl} -k ${params.bwaalnk} -f ${prefix}.r2.sai
bwa sampe -r "@RG\\tID:ILLUMINA-${prefix}\\tSM:${prefix}\\tPL:illumina" $fasta ${prefix}.r1.sai ${prefix}.r2.sai ${reads[0]} ${reads[1]} > tmp.out
realignsamfile -e ${params.circularextension} -i tmp.out -r $fasta $filter
samtools sort -@ ${task.cpus} -O bam tmp_realigned.bam > ${prefix}.sorted.bam
samtools index ${prefix}.sorted.bam
"""
} else {
prefix = reads[0].toString().tokenize('.')[0]
"""
bwa aln -t ${task.cpus} $fasta $reads -n ${params.bwaalnn} -l ${params.bwaalnl} -k ${params.bwaalnk} -f "${reads.baseName}.sai"
bwa samse -r "@RG\\tID:ILLUMINA-${prefix}\\tSM:${prefix}\\tPL:illumina" $fasta "${reads.baseName}".sai $reads > tmp.out
bwa aln -t ${task.cpus} $fasta $reads -n ${params.bwaalnn} -l ${params.bwaalnl} -k ${params.bwaalnk} -f ${prefix}.sai
bwa samse -r "@RG\\tID:ILLUMINA-${prefix}\\tSM:${prefix}\\tPL:illumina" $fasta ${prefix}.sai $reads > tmp.out
realignsamfile -e ${params.circularextension} -i tmp.out -r $fasta $filter
samtools sort -@ ${task.cpus} -O bam tmp_realigned.bam > "${prefix}".sorted.bam
samtools index "${prefix}".sorted.bam
samtools sort -@ ${task.cpus} -O bam tmp_realigned.bam > ${prefix}.sorted.bam
samtools index ${prefix}.sorted.bam
"""
}

}

process bwamem {
Expand All @@ -738,10 +777,18 @@ process bwamem {
script:
prefix = reads[0].toString() - ~/(_R1)?(\.combined\.)?(prefixed)?(_trimmed)?(_val_1)?(\.fq)?(\.fastq)?(\.gz)?$/
fasta = "${index}/*.fasta"
if (!params.singleEnd && params.noCollapse){
"""
bwa mem -t ${task.cpus} $fasta ${reads[0]} ${reads[1]} -R "@RG\\tID:ILLUMINA-${prefix}\\tSM:${prefix}\\tPL:illumina" | samtools sort -@ ${task.cpus} -O bam - > "${prefix}".sorted.bam
samtools index -@ ${task.cpus} "${prefix}".sorted.bam
"""
} else {
"""
bwa mem -t ${task.cpus} $fasta $reads -R "@RG\\tID:ILLUMINA-${prefix}\\tSM:${prefix}\\tPL:illumina" | samtools sort -@ ${task.cpus} -O bam - > "${prefix}".sorted.bam
samtools index -@ ${task.cpus} "${prefix}".sorted.bam
"""
}

}

/*
Expand Down