Bactopia Tool - kraken
¶
The kraken2
module uses Kraken2 to assign taxonomic
classifications to your sequence reads.
Example Usage¶
bactopia --wf kraken \
--bactopia /path/to/your/bactopia/results \
--include includes.txt
Output Overview¶
Below is the default output structure for the kraken
tool. Where possible the
file descriptions below were modified from a tools description.
kraken2/
├── <SAMPLE_NAME>
│ ├── <SAMPLE_NAME>.classified{_1,_2}.fastq.gz
│ ├── <SAMPLE_NAME>.kraken2.report.txt
│ ├── <SAMPLE_NAME>.unclassified{_1,_2}.fastq.gz
│ └── logs
│ └── kraken2
│ ├── nf-kraken2.{begin,err,log,out,run,sh,trace}
│ └── versions.yml
├── logs
│ └── custom_dumpsoftwareversions
│ ├── nf-custom_dumpsoftwareversions.{begin,err,log,out,run,sh,trace}
│ └── versions.yml
├── nf-reports
│ ├── kraken2-dag.dot
│ ├── kraken2-report.html
│ ├── kraken2-timeline.html
│ └── kraken2-trace.txt
├── software_versions.yml
└── software_versions_mqc.yml
Results¶
Kraken2¶
Below is a description of the per-sample results from Kraken2.
Filename | Description |
---|---|
<SAMPLE_NAME>.classified{_1,_2}.fastq.gz | Reads classified to belong to any of the taxa on the Kraken2 database. |
<SAMPLE_NAME>.kraken2.report.txt | Kraken2 report containing stats about classified and not classifed reads. See Kraken2 - Output Formats for more details |
<SAMPLE_NAME>.unclassified{_1,_2}.fastq.gz | Reads not classified to belong to any of the taxa on the Kraken2 database. |
Audit Trail¶
Below are files that can assist you in understanding which parameters and program versions were used.
Logs¶
Each process that is executed will have a logs
folder containing helpful files for you to review
if the need ever arises.
Filename | Description |
---|---|
nf-<PROCESS_NAME>.begin | An empty file used to designate the process started |
nf-<PROCESS_NAME>.err | Contains STDERR outputs from the process |
nf-<PROCESS_NAME>.log | Contains both STDERR and STDOUT outputs from the process |
nf-<PROCESS_NAME>.out | Contains STDOUT outputs from the process |
nf-<PROCESS_NAME>.run | The script Nextflow uses to stage/unstage files and queue processes based on given profile |
nf-<PROCESS_NAME>.sh | The script executed by bash for the process |
nf-<PROCESS_NAME>.trace | The Nextflow Trace report for the process |
versions.yml | A YAML formatted file with program versions |
Nextflow Reports¶
These Nextflow reports provide great a great summary of your run. These can be used to optimize resource usage and estimate expected costs if using cloud platforms.
Filename | Description |
---|---|
kraken-dag.dot | The Nextflow DAG visualisation |
kraken-report.html | The Nextflow Execution Report |
kraken-timeline.html | The Nextflow Timeline Report |
kraken-trace.txt | The Nextflow Trace report |
Program Versions¶
At the end of each run, each of the versions.yml
files are merged into the files below.
Filename | Description |
---|---|
software_versions.yml | A complete list of programs and versions used by each process |
software_versions_mqc.yml | A complete list of programs and versions formatted for MultiQC |
Parameters¶
Required Parameters¶
Define where the pipeline should find input data and save output data.
Parameter | Description | Default |
---|---|---|
--bactopia |
The path to bactopia results to use as inputs |
Filtering Parameters¶
Use these parameters to specify which samples to include or exclude.
Parameter | Description | Default |
---|---|---|
--include |
A text file containing sample names (one per line) to include from the analysis | |
--exclude |
A text file containing sample names (one per line) to exclude from the analysis |
Kraken2 Parameters¶
Parameter | Description | Default |
---|---|---|
--kraken2_db |
The path to a Kraken2 formatted database | |
--quick_mode |
Quick operation (use first hit or hits) | False |
--confidence |
Confidence score threshold between 0 and 1 | 0.0 |
--minimum_base_quality |
Minimum base quality used in classification | 0 |
--use_mpa_style |
Format report output like Kraken 1's kraken-mpa-report | False |
--report_zero_counts |
Report counts for ALL taxa, even if counts are zero | False |
--report_minimizer_data |
Include minimizer and distinct minimizer count information in report | False |
--use_names |
Print scientific names instead of just taxids | False |
--memory_mapping |
Avoid loading database into RAM | False |
--minimum_hit_groups |
Minimum number of hit groups needed to make a call | 2 |
Optional Parameters¶
These optional parameters can be useful in certain settings.
Parameter | Description | Default |
---|---|---|
--outdir |
Base directory to write results to | ./ |
--run_name |
Name of the directory to hold results | bactopia |
--skip_compression |
Ouput files will not be compressed | False |
--keep_all_files |
Keeps all analysis files created | False |
Max Job Request Parameters¶
Set the top limit for requested resources for any single job.
Parameter | Description | Default |
---|---|---|
--max_retry |
Maximum times to retry a process before allowing it to fail. | 3 |
--max_cpus |
Maximum number of CPUs that can be requested for any single job. | 4 |
--max_memory |
Maximum amount of memory (in GB) that can be requested for any single job. | 32 |
--max_time |
Maximum amount of time (in minutes) that can be requested for any single job. | 120 |
--max_downloads |
Maximum number of samples to download at a time | 3 |
Nextflow Configuration Parameters¶
Parameters to fine-tune your Nextflow setup.
Parameter | Description | Default |
---|---|---|
--nfconfig |
A Nextflow compatible config file for custom profiles, loaded last and will overwrite existing variables if set. | |
--publish_dir_mode |
Method used to save pipeline results to output directory. | copy |
--infodir |
Directory to keep pipeline Nextflow logs and reports. | ${params.outdir}/pipeline_info |
--force |
Nextflow will overwrite existing output files. | False |
--cleanup_workdir |
After Bactopia is successfully executed, the work directory will be deleted. |
False |
Nextflow Profile Parameters¶
Parameters to fine-tune your Nextflow setup.
Parameter | Description | Default |
---|---|---|
--condadir |
Directory to Nextflow should use for Conda environments | |
--registry |
Docker registry to pull containers from. | dockerhub |
--singularity_cache |
Directory where remote Singularity images are stored. | |
--singularity_pull_docker_container |
Instead of directly downloading Singularity images for use with Singularity, force the workflow to pull and convert Docker containers instead. | |
--force_rebuild |
Force overwrite of existing pre-built environments. | False |
--queue |
Comma-separated name of the queue(s) to be used by a job scheduler (e.g. AWS Batch or SLURM) | general,high-memory |
--cluster_opts |
Additional options to pass to the executor. (e.g. SLURM: '--account=my_acct_name' | |
--disable_scratch |
All intermediate files created on worker nodes of will be transferred to the head node. | False |
Helpful Parameters¶
Uncommonly used parameters that might be useful.
Parameter | Description | Default |
---|---|---|
--monochrome_logs |
Do not use coloured log outputs. | |
--nfdir |
Print directory Nextflow has pulled Bactopia to | |
--sleep_time |
The amount of time (seconds) Nextflow will wait after setting up datasets before execution. | 5 |
--validate_params |
Boolean whether to validate parameters against the schema at runtime | True |
--help |
Display help text. | |
--wf |
Specify which workflow or Bactopia Tool to execute | bactopia |
--list_wfs |
List the available workflows and Bactopia Tools to use with '--wf' | |
--show_hidden_params |
Show all params when using --help |
|
--help_all |
An alias for --help --show_hidden_params | |
--version |
Display version text. |
Citations¶
If you use Bactopia and kraken
in your analysis, please cite the following.
-
Bactopia
Petit III RA, Read TD Bactopia - a flexible pipeline for complete analysis of bacterial genomes. mSystems 5 (2020) -
Kraken2
Wood DE, Lu J, Langmead B Improved metagenomic analysis with Kraken 2. Genome Biology, 20(1), 257. (2019)