Skip to content

Commit

Permalink
Merge pull request #210 from ziadbkh/postprocessing-sub-workflow
Browse files Browse the repository at this point in the history
Moving post-processing logic to a subworkflow
JoseEspinosa authored Nov 4, 2024
2 parents bb0c659 + 92ac346 commit 3d63859
Showing 7 changed files with 454 additions and 238 deletions.
129 changes: 54 additions & 75 deletions main.nf
Original file line number Diff line number Diff line change
@@ -32,10 +32,7 @@ include { PIPELINE_INITIALISATION } from './subworkflows/local/utils_nf
include { PIPELINE_COMPLETION } from './subworkflows/local/utils_nfcore_proteinfold_pipeline'
include { getColabfoldAlphafold2Params } from './subworkflows/local/utils_nfcore_proteinfold_pipeline'
include { getColabfoldAlphafold2ParamsPath } from './subworkflows/local/utils_nfcore_proteinfold_pipeline'

include { GENERATE_REPORT } from './modules/local/generate_report'
include { COMPARE_STRUCTURES } from './modules/local/compare_structures'
include { FOLDSEEK_EASYSEARCH } from './modules/nf-core/foldseek/easysearch/main'
include { POST_PROCESSING } from './subworkflows/local/post_processing'

/*
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
@@ -61,11 +58,15 @@ workflow NFCORE_PROTEINFOLD {
samplesheet // channel: samplesheet read in from --input

main:
ch_samplesheet = samplesheet
ch_multiqc = Channel.empty()
ch_versions = Channel.empty()
ch_report_input = Channel.empty()
requested_modes = params.mode.toLowerCase().split(",")
ch_samplesheet = samplesheet
ch_multiqc = Channel.empty()
ch_versions = Channel.empty()
ch_report_input = Channel.empty()
ch_foldseek_db = Channel.empty()
ch_colabfold_out = Channel.empty()
ch_esmfold_out = Channel.empty()
ch_alphafold2_out = Channel.empty()
requested_modes = params.mode.toLowerCase().split(",")
//
// WORKFLOW: Run alphafold2
//
@@ -121,11 +122,16 @@ workflow NFCORE_PROTEINFOLD {
PREPARE_ALPHAFOLD2_DBS.out.pdb_seqres,
PREPARE_ALPHAFOLD2_DBS.out.uniprot
)
ch_multiqc = ALPHAFOLD2.out.multiqc_report
ch_multiqc = ch_multiqc.mix(ALPHAFOLD2.out.multiqc_report.collect())
ch_versions = ch_versions.mix(ALPHAFOLD2.out.versions)
ch_report_input = ch_report_input.mix(
ALPHAFOLD2.out.pdb.join(ALPHAFOLD2.out.msa).map{it[0]["model"] = "alphafold2"; it}
)
ALPHAFOLD2
.out
.main_pdb
.map{[it[0]["id"], it[0], it[1]]}
.set{ch_alphafold2_out}
}

//
@@ -160,7 +166,7 @@ workflow NFCORE_PROTEINFOLD {
PREPARE_COLABFOLD_DBS.out.uniref30,
params.num_recycles_colabfold
)
ch_multiqc = COLABFOLD.out.multiqc_report
ch_multiqc = ch_multiqc.mix(COLABFOLD.out.multiqc_report)
ch_versions = ch_versions.mix(COLABFOLD.out.versions)
ch_report_input = ch_report_input.mix(
COLABFOLD
@@ -169,6 +175,14 @@ workflow NFCORE_PROTEINFOLD {
.join(COLABFOLD.out.msa)
.map { it[0]["model"] = "colabfold"; it }
)
COLABFOLD
.out
.main_pdb
.map{[it[0]["id"], it[0], it[1]]}
.join(COLABFOLD.out.msa
.map{[it[0]["id"], it[1]]},
remainder:true
).set{ch_colabfold_out}
}

//
@@ -196,84 +210,49 @@ workflow NFCORE_PROTEINFOLD {
PREPARE_ESMFOLD_DBS.out.params,
params.num_recycles_esmfold
)
ch_multiqc = ESMFOLD.out.multiqc_report
ch_multiqc = ch_multiqc.mix(ESMFOLD.out.multiqc_report.collect())
ch_versions = ch_versions.mix(ESMFOLD.out.versions)
ch_report_input = ch_report_input.mix(
ESMFOLD.out.pdb.combine(Channel.fromPath("$projectDir/assets/NO_FILE")).map{it[0]["model"] = "esmfold"; it}
)
ch_report_input.filter{it[0]["model"] == "esmfold"}
.map{[it[0]["id"], it[0], it[1], it[2]]}
.set{ch_esmfold_out}
}
//
// POST PROCESSING: generate visulaisation reports
//
if (!params.skip_visualisation){
GENERATE_REPORT(
ch_report_input.map{[it[0], it[1]]},
ch_report_input.map{[it[0], it[2]]},
ch_report_input.map{it[0].model},
Channel.fromPath("$projectDir/assets/proteinfold_template.html", checkIfExists: true).first()
)
ch_versions = ch_versions.mix(GENERATE_REPORT.out.versions)
//GENERATE_REPORT.out.sequence_coverage.view()
if (requested_modes.size() > 1){
ch_report_input.filter{it[0]["model"] == "esmfold"}
.map{[it[0]["id"], it[0], it[1], it[2]]}
.set{ch_comparision_report_files}

if (requested_modes.contains("alphafold2")) {
ch_comparision_report_files = ch_comparision_report_files.mix(
ALPHAFOLD2
.out
.main_pdb
.map{[it[0]["id"], it[0], it[1]]}
.join(GENERATE_REPORT.out.sequence_coverage
.filter{it[0]["model"] == "alphafold2"}
.map{[it[0]["id"], it[1]]}, remainder:true
)
)
}
if (requested_modes.contains("colabfold")) {
ch_comparision_report_files = ch_comparision_report_files.mix(
COLABFOLD
.out
.main_pdb
.map{[it[0]["id"], it[0], it[1]]}
.join(COLABFOLD.out.msa
.map{[it[0]["id"], it[1]]},
remainder:true
)
)
}

ch_comparision_report_files
.groupTuple(by: [0], size: requested_modes.size())
.set{ch_comparision_report_input}

COMPARE_STRUCTURES(
ch_comparision_report_input.map{it[1][0]["models"] = params.mode.toLowerCase(); [it[1][0], it[2]]},
ch_comparision_report_input.map{it[1][0]["models"] = params.mode.toLowerCase(); [it[1][0], it[3]]},
Channel.fromPath("$projectDir/assets/comparison_template.html", checkIfExists: true).first()
)
ch_versions = ch_versions.mix(COMPARE_STRUCTURES.out.versions)
}
}

if (params.foldseek_search == "easysearch"){
ch_foldseek_db = channel.value([["id": params.foldseek_db],
file(params.foldseek_db_path,
checkIfExists: true)])

FOLDSEEK_EASYSEARCH(
ch_report_input
.map{
if (it[0].model == "esmfold")
[it[0], it[1]]
else
[it[0], it[1][0]]
},
ch_foldseek_db
)
}

ch_multiqc_config = params.multiqc_config ? Channel.fromPath( params.multiqc_config ) : Channel.empty()
ch_multiqc_logo = params.multiqc_logo ? Channel.fromPath( params.multiqc_logo ) : Channel.empty()
ch_multiqc_methods_description = params.multiqc_methods_description ? file(params.multiqc_methods_description, checkIfExists: true) : file("$projectDir/assets/methods_description_template.yml", checkIfExists: true)
//ch_multiqc.view()
POST_PROCESSING(
params.skip_visualisation,
requested_modes.size(),
ch_report_input,
Channel.fromPath("$projectDir/assets/proteinfold_template.html", checkIfExists: true).first(),
Channel.fromPath("$projectDir/assets/comparison_template.html", checkIfExists: true).first(),
params.foldseek_search,
ch_foldseek_db,
params.skip_multiqc,
params.outdir,
ch_versions,
ch_multiqc,
Channel.fromPath("$projectDir/assets/multiqc_config.yml", checkIfExists: true).first(),
ch_multiqc_config.first(),
ch_multiqc_logo.first(),
ch_multiqc_methods_description.first(),
ch_alphafold2_out,
ch_esmfold_out,
ch_colabfold_out
)

emit:
multiqc_report = ch_multiqc
}
6 changes: 3 additions & 3 deletions modules/nf-core/multiqc/main.nf

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

264 changes: 261 additions & 3 deletions modules/nf-core/multiqc/multiqc.diff

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

130 changes: 130 additions & 0 deletions subworkflows/local/post_processing.nf
Original file line number Diff line number Diff line change
@@ -0,0 +1,130 @@
//
// Post processing analysis for the predected structures
//

//
// SUBWORKFLOW: Consisting entirely of nf-core/modules
//
include { paramsSummaryMap } from 'plugin/nf-schema'
include { paramsSummaryMultiqc } from '../nf-core/utils_nfcore_pipeline'
include { softwareVersionsToYAML } from '../nf-core/utils_nfcore_pipeline'
include { methodsDescriptionText } from './utils_nfcore_proteinfold_pipeline'

include { GENERATE_REPORT } from '../../modules/local/generate_report'
include { COMPARE_STRUCTURES } from '../../modules/local/compare_structures'
include { FOLDSEEK_EASYSEARCH } from '../../modules/nf-core/foldseek/easysearch/main'
include { MULTIQC } from '../../modules/nf-core/multiqc/main'


workflow POST_PROCESSING {

take:
skip_visualisation
requested_modes_size
ch_report_input
ch_proteinfold_template
ch_comparison_template
foldseek_search
ch_foldseek_db
skip_multiqc
outdir
ch_versions
ch_multiqc_rep
ch_multiqc_config
ch_multiqc_custom_config
ch_multiqc_logo
ch_multiqc_custom_methods_description
ch_alphafold2_out
ch_esmfold_out
ch_colabfold_out

main:
ch_comparision_report_files = Channel.empty()

if (!skip_visualisation){
GENERATE_REPORT(
ch_report_input.map{[it[0], it[1]]},
ch_report_input.map{[it[0], it[2]]},
ch_report_input.map{it[0].model},
ch_proteinfold_template
)
ch_versions = ch_versions.mix(GENERATE_REPORT.out.versions)

if (requested_modes_size > 1){
ch_comparision_report_files = ch_comparision_report_files.mix(ch_alphafold2_out
.join(GENERATE_REPORT.out.sequence_coverage
.filter{it[0]["model"] == "alphafold2"}
.map{[it[0]["id"], it[1]]}, remainder:true
)
)

ch_comparision_report_files = ch_comparision_report_files.mix(
ch_colabfold_out
)

ch_comparision_report_files = ch_comparision_report_files.mix(
ch_esmfold_out
)
//ch_comparision_report_files.view()
ch_comparision_report_files
.groupTuple(by: [0], size: requested_modes_size)
.set{ch_comparision_report_input}

COMPARE_STRUCTURES(
ch_comparision_report_input.map{it[1][0]["models"] = params.mode.toLowerCase(); [it[1][0], it[2]]},
ch_comparision_report_input.map{it[1][0]["models"] = params.mode.toLowerCase(); [it[1][0], it[3]]},
ch_comparison_template
)
ch_versions = ch_versions.mix(COMPARE_STRUCTURES.out.versions)
}
}

if (foldseek_search == "easysearch"){
FOLDSEEK_EASYSEARCH(
ch_report_input
.map{
if (it[0].model == "esmfold")
[it[0], it[1]]
else
[it[0], it[1][0]]
},
ch_foldseek_db
)
}

//
// Collate and save software versions
//
softwareVersionsToYAML(ch_versions)
.collectFile(storeDir: "${outdir}/pipeline_info", name: 'nf_core_proteinfold_software_versions.yml', sort: true, newLine: true)
.set { ch_collated_versions }
//
// MODULE: MultiQC
//
if (!skip_multiqc) {
summary_params = paramsSummaryMap(workflow, parameters_schema: "nextflow_schema.json")
ch_workflow_summary = Channel.value(paramsSummaryMultiqc(summary_params))
ch_multiqc_custom_methods_description = params.multiqc_methods_description ? file(params.multiqc_methods_description, checkIfExists: true) : file("$projectDir/assets/methods_description_template.yml", checkIfExists: true)
ch_methods_description = Channel.value(methodsDescriptionText(ch_multiqc_custom_methods_description))

ch_multiqc_files = Channel.empty()
ch_multiqc_files = ch_multiqc_files.mix(ch_workflow_summary.collectFile(name: 'workflow_summary_mqc.yaml'))
ch_multiqc_files = ch_multiqc_files.mix(ch_methods_description.collectFile(name: 'methods_description_mqc.yaml'))
ch_multiqc_files = ch_multiqc_files.mix(ch_collated_versions)
MULTIQC (
ch_multiqc_rep.combine(ch_multiqc_files.collect().map{[it]}).map{[it[0], it[1] + it[2]]},
ch_multiqc_config,
ch_multiqc_custom_config.collect().ifEmpty([]),
ch_multiqc_logo.collect().ifEmpty([]),
[],
[]
)
ch_multiqc_report = MULTIQC.out.report.toList()
}else{
ch_multiqc_report = Channel.empty()
}

emit:
versions = ch_versions
multiqc_report = ch_multiqc_report
}
57 changes: 4 additions & 53 deletions workflows/alphafold2.nf
Original file line number Diff line number Diff line change
@@ -17,19 +17,6 @@ include { RUN_ALPHAFOLD2_PRED } from '../modules/local/run_alphafold2_pred'
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
*/

//
// MODULE: Installed directly from nf-core/modules
//
include { MULTIQC } from '../modules/nf-core/multiqc/main'

//
// SUBWORKFLOW: Consisting entirely of nf-core/modules
//
include { paramsSummaryMap } from 'plugin/nf-schema'
include { paramsSummaryMultiqc } from '../subworkflows/nf-core/utils_nfcore_pipeline'
include { softwareVersionsToYAML } from '../subworkflows/nf-core/utils_nfcore_pipeline'
include { methodsDescriptionText } from '../subworkflows/local/utils_nfcore_proteinfold_pipeline'

/*
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
RUN MAIN WORKFLOW
@@ -60,6 +47,7 @@ workflow ALPHAFOLD2 {
ch_pdb = Channel.empty()
ch_main_pdb = Channel.empty()
ch_msa = Channel.empty()
ch_multiqc_rep = Channel.empty()

if (alphafold2_model_preset != 'multimer') {
ch_samplesheet
@@ -93,7 +81,7 @@ workflow ALPHAFOLD2 {
ch_pdb = ch_pdb.mix(RUN_ALPHAFOLD2.out.pdb)
ch_main_pdb = ch_main_pdb.mix(RUN_ALPHAFOLD2.out.main_pdb)
ch_msa = ch_msa.mix(RUN_ALPHAFOLD2.out.msa)
ch_multiqc_rep = RUN_ALPHAFOLD2.out.multiqc.map{it[1]}.collect()
ch_multiqc_rep = RUN_ALPHAFOLD2.out.multiqc.map{it[1]}.toSortedList().map{[["model":"alphafold2"], it]}
ch_versions = ch_versions.mix(RUN_ALPHAFOLD2.out.versions)

} else if (alphafold2_mode == 'split_msa_prediction') {
@@ -136,52 +124,15 @@ workflow ALPHAFOLD2 {
ch_pdb = ch_pdb.mix(RUN_ALPHAFOLD2_PRED.out.pdb)
ch_main_pdb = ch_main_pdb.mix(RUN_ALPHAFOLD2_PRED.out.main_pdb)
ch_msa = ch_msa.mix(RUN_ALPHAFOLD2_PRED.out.msa)
ch_multiqc_rep = RUN_ALPHAFOLD2_PRED.out.multiqc.map{it[1]}.collect()
ch_multiqc_rep = RUN_ALPHAFOLD2_PRED.out.multiqc.map{it[1]}.toSortedList().map{[["model":"alphafold2"], it]}
ch_versions = ch_versions.mix(RUN_ALPHAFOLD2_PRED.out.versions)
}

//
// Collate and save software versions
//
softwareVersionsToYAML(ch_versions)
.collectFile(storeDir: "${params.outdir}/pipeline_info", name: 'nf_core_proteinfold_software_mqc_alphafold2_versions.yml', sort: true, newLine: true)
.set { ch_collated_versions }
//
// MODULE: MultiQC
//
ch_multiqc_report = Channel.empty()
if (!params.skip_multiqc) {
ch_multiqc_report = Channel.empty()
ch_multiqc_config = Channel.fromPath("$projectDir/assets/multiqc_config.yml", checkIfExists: true)
ch_multiqc_custom_config = params.multiqc_config ? Channel.fromPath( params.multiqc_config ) : Channel.empty()
ch_multiqc_logo = params.multiqc_logo ? Channel.fromPath( params.multiqc_logo ) : Channel.empty()
summary_params = paramsSummaryMap(workflow, parameters_schema: "nextflow_schema.json")
ch_workflow_summary = Channel.value(paramsSummaryMultiqc(summary_params))
ch_multiqc_custom_methods_description = params.multiqc_methods_description ? file(params.multiqc_methods_description, checkIfExists: true) : file("$projectDir/assets/methods_description_template.yml", checkIfExists: true)
ch_methods_description = Channel.value(methodsDescriptionText(ch_multiqc_custom_methods_description))

ch_multiqc_files = Channel.empty()
ch_multiqc_files = ch_multiqc_files.mix(ch_workflow_summary.collectFile(name: 'workflow_summary_mqc.yaml'))
ch_multiqc_files = ch_multiqc_files.mix(ch_methods_description.collectFile(name: 'methods_description_mqc.yaml'))
ch_multiqc_files = ch_multiqc_files.mix(ch_collated_versions)
ch_multiqc_files = ch_multiqc_files.mix(ch_multiqc_rep)

MULTIQC (
ch_multiqc_files.collect(),
ch_multiqc_config.toList(),
ch_multiqc_custom_config.toList(),
ch_multiqc_logo.toList(),
[],
[]
)
ch_multiqc_report = MULTIQC.out.report.toList()
}

emit:
main_pdb = ch_main_pdb // channel: /path/to/*.pdb
pdb = ch_pdb // channel: /path/to/*.pdb
msa = ch_msa // channel: /path/to/*msa.tsv
multiqc_report = ch_multiqc_report // channel: /path/to/multiqc_report.html
multiqc_report = ch_multiqc_rep // channel: /path/to/multiqc_report.html
versions = ch_versions // channel: [ path(versions.yml) ]
}

53 changes: 1 addition & 52 deletions workflows/colabfold.nf
Original file line number Diff line number Diff line change
@@ -17,19 +17,6 @@ include { MULTIFASTA_TO_CSV } from '../modules/local/multifasta_to_csv'
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
*/

//
// MODULE: Installed directly from nf-core/modules
//
include { MULTIQC } from '../modules/nf-core/multiqc/main'

//
// SUBWORKFLOW: Consisting entirely of nf-core/modules
//
include { paramsSummaryMap } from 'plugin/nf-schema'
include { paramsSummaryMultiqc } from '../subworkflows/nf-core/utils_nfcore_pipeline'
include { softwareVersionsToYAML } from '../subworkflows/nf-core/utils_nfcore_pipeline'
include { methodsDescriptionText } from '../subworkflows/local/utils_nfcore_proteinfold_pipeline'

/*
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
RUN MAIN WORKFLOW
@@ -120,49 +107,11 @@ workflow COLABFOLD {
ch_versions = ch_versions.mix(COLABFOLD_BATCH.out.versions)
}

//
// Collate and save software versions
//
softwareVersionsToYAML(ch_versions)
.collectFile(storeDir: "${params.outdir}/pipeline_info", name: 'nf_core_proteinfold_software_mqc_colabfold_versions.yml', sort: true, newLine: true)
.set { ch_collated_versions }

//
// MODULE: MultiQC
//
ch_multiqc_report = Channel.empty()
if (!params.skip_multiqc) {
ch_multiqc_report = Channel.empty()
ch_multiqc_config = Channel.fromPath("$projectDir/assets/multiqc_config.yml", checkIfExists: true)
ch_multiqc_custom_config = params.multiqc_config ? Channel.fromPath( params.multiqc_config ) : Channel.empty()
ch_multiqc_logo = params.multiqc_logo ? Channel.fromPath( params.multiqc_logo ) : Channel.empty()
summary_params = paramsSummaryMap(workflow, parameters_schema: "nextflow_schema.json")
ch_workflow_summary = Channel.value(paramsSummaryMultiqc(summary_params))
ch_multiqc_custom_methods_description = params.multiqc_methods_description ? file(params.multiqc_methods_description, checkIfExists: true) : file("$projectDir/assets/methods_description_template.yml", checkIfExists: true)
ch_methods_description = Channel.value(methodsDescriptionText(ch_multiqc_custom_methods_description))

ch_multiqc_files = Channel.empty()
ch_multiqc_files = ch_multiqc_files.mix(ch_workflow_summary.collectFile(name: 'workflow_summary_mqc.yaml'))
ch_multiqc_files = ch_multiqc_files.mix(ch_methods_description.collectFile(name: 'methods_description_mqc.yaml'))
ch_multiqc_files = ch_multiqc_files.mix(ch_collated_versions)
ch_multiqc_files = ch_multiqc_files.mix(COLABFOLD_BATCH.out.multiqc.map{it[1]}.collect())

MULTIQC (
ch_multiqc_files.collect(),
ch_multiqc_config.toList(),
ch_multiqc_custom_config.toList(),
ch_multiqc_logo.toList(),
[],
[]
)
ch_multiqc_report = MULTIQC.out.report.toList()
}

emit:
pdb = COLABFOLD_BATCH.out.pdb // channel: /path/to/*.pdb
main_pdb = COLABFOLD_BATCH.out.main_pdb // channel: /path/to/*.pdb
msa = COLABFOLD_BATCH.out.msa // channel: /path/to/*_coverage.png
multiqc_report = ch_multiqc_report // channel: /path/to/multiqc_report.html
multiqc_report = COLABFOLD_BATCH.out.multiqc.map{it[1]}.flatten().toList().map{[["model":"colabfold"], it]} // channel: /path/to/multiqc_report.html
versions = ch_versions // channel: [ path(versions.yml) ]
}

53 changes: 1 addition & 52 deletions workflows/esmfold.nf
Original file line number Diff line number Diff line change
@@ -16,19 +16,6 @@ include { MULTIFASTA_TO_SINGLEFASTA } from '../modules/local/multifasta_to_singl
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
*/

//
// MODULE: Installed directly from nf-core/modules
//
include { MULTIQC } from '../modules/nf-core/multiqc/main'

//
// SUBWORKFLOW: Consisting entirely of nf-core/modules
//
include { paramsSummaryMap } from 'plugin/nf-schema'
include { paramsSummaryMultiqc } from '../subworkflows/nf-core/utils_nfcore_pipeline'
include { softwareVersionsToYAML } from '../subworkflows/nf-core/utils_nfcore_pipeline'
include { methodsDescriptionText } from '../subworkflows/local/utils_nfcore_proteinfold_pipeline'

/*
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
RUN MAIN WORKFLOW
@@ -69,47 +56,9 @@ workflow ESMFOLD {
ch_versions = ch_versions.mix(RUN_ESMFOLD.out.versions)
}

//
// Collate and save software versions
//
softwareVersionsToYAML(ch_versions)
.collectFile(storeDir: "${params.outdir}/pipeline_info", name: 'nf_core_proteinfold_software_mqc_esmfold_versions.yml', sort: true, newLine: true)
.set { ch_collated_versions }

//
// MODULE: MultiQC
//
ch_multiqc_report = Channel.empty()
if (!params.skip_multiqc) {
ch_multiqc_report = Channel.empty()
ch_multiqc_config = Channel.fromPath("$projectDir/assets/multiqc_config.yml", checkIfExists: true)
ch_multiqc_custom_config = params.multiqc_config ? Channel.fromPath( params.multiqc_config ) : Channel.empty()
ch_multiqc_logo = params.multiqc_logo ? Channel.fromPath( params.multiqc_logo ) : Channel.empty()
summary_params = paramsSummaryMap(workflow, parameters_schema: "nextflow_schema.json")
ch_workflow_summary = Channel.value(paramsSummaryMultiqc(summary_params))
ch_multiqc_methods_description = params.multiqc_methods_description ? file(params.multiqc_methods_description, checkIfExists: true) : file("$projectDir/assets/methods_description_template.yml", checkIfExists: true)
ch_methods_description = Channel.value(methodsDescriptionText(ch_multiqc_methods_description))

ch_multiqc_files = Channel.empty()
ch_multiqc_files = ch_multiqc_files.mix(ch_workflow_summary.collectFile(name: 'workflow_summary_mqc.yaml'))
ch_multiqc_files = ch_multiqc_files.mix(ch_methods_description.collectFile(name: 'methods_description_mqc.yaml'))
ch_multiqc_files = ch_multiqc_files.mix(ch_collated_versions)
ch_multiqc_files = ch_multiqc_files.mix(RUN_ESMFOLD.out.multiqc.map{it[1]}.collect())

MULTIQC (
ch_multiqc_files.collect(),
ch_multiqc_config.toList(),
ch_multiqc_custom_config.toList(),
ch_multiqc_logo.toList(),
[],
[]
)
ch_multiqc_report = MULTIQC.out.report.toList()
}

emit:
pdb = RUN_ESMFOLD.out.pdb // channel: /path/to/*pdb
multiqc_report = ch_multiqc_report // channel: /path/to/multiqc_report.html
multiqc_report = RUN_ESMFOLD.out.multiqc.map{it[1]}.toSortedList().map{[["model":"esmfold"], it]} // channel: /path/to/multiqc_report.html
versions = ch_versions // channel: [ path(versions.yml) ]
}

0 comments on commit 3d63859

Please sign in to comment.