Skip to content
Snippets Groups Projects
kmerclust.nf 2.91 KiB
Newer Older
process KMERCLUST_LOAD {
Laurent Modolo's avatar
Laurent Modolo committed
    tag "$specie"
    label 'big_mem_mono_cpus'
    container "lbmc/kmerclust:0.1.0"
    publishDir "results/${params.kmer_size}/${specie}/", mode: 'copy'
Laurent Modolo's avatar
Laurent Modolo committed

    input:
    tuple val(specie), path(csv)
Laurent Modolo's avatar
Laurent Modolo committed

    output:
    tuple val(specie), path("*.Rdata"), emit: rdata 
Laurent Modolo's avatar
Laurent Modolo committed
    path "versions.yml"           , emit: versions

    script:
    def args = task.ext.args ?: ''
    """
    Rscript ${projectDir}/bin/kmerclust_load.R ${params_csv} ${csv} ${specie}

    cat <<-END_VERSIONS > versions.yml
    "${task.process}":
    END_VERSIONS
    """
}

process KMERCLUST_BOOT {
    tag "$specie"
    label 'big_mem_multi_cpus'

    container "lbmc/kmerclust:0.1.0"
    publishDir "results/${params.kmer_size}/${specie}/", mode: 'copy'

    input:
    tuple val(id), val(specie), path(rdata)

    output:
    tuple val(specie), path("*.Rdata"), emit: rdata 
    path "versions.yml"           , emit: versions

    script:
    def args = task.ext.args ?: ''
    """
    Rscript ${projectDir}/bin/kmerclust_boot.R ${specie} ${task.cpus} ${id}

    cat <<-END_VERSIONS > versions.yml
    "${task.process}":
    container "lbmc/kmerclust:0.1.0"
    publishDir "results/${params.kmer_size}/${specie}/", mode: 'copy'

    input:
    tuple val(id), val(specie), path(rdata)

    output:
    tuple val(specie), path("*.Rdata"), emit: rdata 
    path "versions.yml"           , emit: versions

    script:
    def args = task.ext.args ?: ''
    """
    Rscript ${projectDir}/bin/kmerclust_clust.R ${specie} ${task.cpus} ${id}

    cat <<-END_VERSIONS > versions.yml
    "${task.process}":
    END_VERSIONS
    """
}

process KMERCLUST_MERGE {
    tag "$specie"
    label 'big_mem_mono_cpus'
    container "lbmc/kmerclust:0.1.0"
    publishDir "results/${params.kmer_size}/${specie}/", mode: 'copy'

    input:
    tuple val(specie), path(rdata)

    output:
    tuple val(specie), path("*.Rdata"), emit: rdata 
    path "versions.yml"           , emit: versions

    script:
    def args = task.ext.args ?: ''
    """
    Rscript ${projectDir}/bin/kmerclust_merge.R ${specie}
Laurent Modolo's avatar
Laurent Modolo committed

    cat <<-END_VERSIONS > versions.yml
    "${task.process}":
Laurent Modolo's avatar
Laurent Modolo committed
    END_VERSIONS
    """
}

process KMERCLUST_PLOT {
    tag "$specie"
    label 'big_mem_mono_cpus'

    container "lbmc/kmerclust:0.1.0"
    publishDir "results/${params.kmer_size}/${specie}/", mode: 'copy'

    input:
    tuple val(specie), path(rdata)

    output:
    tuple val(specie), path("*.pdf"), emit: pdf 
    path "versions.yml"           , emit: versions

    script:
    def args = task.ext.args ?: ''
    """
    Rscript ${projectDir}/bin/kmerclust_plot.R ${specie}

    cat <<-END_VERSIONS > versions.yml
    "${task.process}":
    END_VERSIONS
    """
}