-
Notifications
You must be signed in to change notification settings - Fork 0
Home
This Wiki describes in detail how to use Tourmaline. Navigate using the sidebar on the right.
Tourmaline is an amplicon sequence processing workflow for Illumina sequence data that uses QIIME 2 and the software packages it wraps. Tourmaline manages commands, inputs, and outputs using the Snakemake workflow management system.
Tourmaline has several features that enhance usability and interoperability:
- Portability. Native support for Linux and macOS in addition to Docker containers.
- QIIME 2. The core commands of Tourmaline, including the DADA2 package, are all commands of QIIME 2, one of the most popular amplicon sequence analysis software tools available. You can print all of the QIIME 2 and other shell commands of your workflow before or while running the workflow.
-
Snakemake. Managing the workflow with Snakemake provides several benefits:
- Configuration file contains all parameters in one file, so you can see what your workflow is doing and make changes for a subsequent run.
- Directory structure is the same for every Tourmaline run, so you always know where your outputs are.
- On-demand commands mean that only the commands required for output files not yet generated are run, saving time and computation when re-running part of a workflow.
- Parameter optimization. The configuration file and standard directory structure make it simple to test and compare different parameter sets to optimize your workflow. Included code helps choose read truncation parameters and identify outliers in representative sequences (ASVs).
- Reports. Every Tourmaline run produces an HTML report containing a summary of your metadata and outputs, with links to web-viewable QIIME 2 visualization files.
- Downstream analysis. Analyze the output of single or multiple Tourmaline runs programmatically, with qiime2R in R or the QIIME 2 Artifact API in Python, using the provided R and Python notebooks or your own code.
If you have used QIIME 2 before, you might be wondering which QIIME 2 commands Tourmaline uses and supports. All commands are specified as rules in Snakefile
, and typical workflows without and with sequence filtering are shown as directed acyclic graphs in the folder dags
. Briefly, here are the main QIIME 2 options supported, with QIIME 2 visualization (.qzv) outputs indicated:
- FASTQ sequence import using a manifest file, or use your pre-imported FASTQ .qza file
- Denoising with DADA2 (paired-end and single-end) and Deblur (single-end)
- Feature classification (taxonomic assignment) with options of consensus BLAST and naive Bayes
- Feature filtering by taxonomy and by feature ID
- Interactive taxonomy barplot (.qzv)
- De novo multiple sequence alignment with MAFFT (with masking) and tree building with Fasttree
- Tree visualization using Empress (.qzv)
- Alpha diversity, alpha rarefaction, and alpha group significance with four metrics: Faith's phylogenetic diversity, observed features, Shannon diversity, and Pielou's evenness (.qzv)
- Beta diversity distances, principal coordinates, Emperor plots, and beta group significance (one metadata column) with four metrics: unweighted UniFrac, weighted UniFrac, Jaccard distance, and Bray-Curtis distance (.qzv)
If this is your first time using Tourmaline or Snakemake, you may want to browse through the Wiki for a detailed walkthrough. If you want to get started right away, check out the Quick Start below.
Tourmaline provides Snakemake rules for DADA2 (single-end and paired-end) and Deblur (single-end). For each type of processing, there are four steps:
- the denoise rule imports FASTQ data and runs denoising, generating a feature table and representative sequences;
- the taxonomy rule assigns taxonomy to representative sequences;
- the diversity rule does representative sequence curation, core diversity analyses, and alpha and beta group significance; and
- the report rule generates an HTML report of the outputs plus metadata, inputs, and parameters. Also, the report rule can be run immediately to run the entire workflow.
Steps 2–4 have unfiltered and filtered modes, the difference being that in the taxonomy step of filtered mode, undesired taxonomic groups or individual sequences from the representative sequences and feature table are removed. The diversity and report rules are the same for unfiltered and filtered modes, except the output goes into separate subdirectories.
Before you download the Tourmaline commands and directory structure from GitHub, you first need to install QIIME 2, Snakemake, and the other dependencies of Tourmaline. Two options are provided: a native installation on a Mac or Linux system and a Docker image/container.
To run Tourmaline natively on a Mac or Linux system, start with a Conda installation of QIIME 2 and add the other dependencies:
wget https://data.qiime2.org/distro/core/qiime2-2021.2-py36-osx-conda.yml
conda env create -n qiime2-2021.2 --file qiime2-2021.2-py36-osx-conda.yml
conda activate qiime2-2021.2
conda install -c bioconda snakemake biopython tabulate pandoc tabview
pip install git+https://github.com/biocore/empress.git
qiime dev refresh-cache
Finally, open R by entering R
and install the R dependencies:
if (!requireNamespace("BiocManager", quietly = TRUE))
install.packages("BiocManager")
BiocManager::install("msa")
BiocManager::install("odseq")
To run Tourmaline inside a Docker container:
- Install Docker Desktop (Mac or Windows) or Docker (Linux) from Docker.com.
- Increase the memory to 8 GB or more (Preferences -> Resources -> Advanced -> Memory).
- Download the Docker image from DockerHub (command below).
- Run the Docker image (command below).
docker pull aomlomics/tourmaline
docker run -v $HOME:/data -it aomlomics/tourmaline
The -v
(volume) flag above allows you to mount a local file system volume (in this case your home directory) to read/write from your container. Use mounted volumes to copy metadata and manifest files to your container, create symbolic links from your container to your FASTQ files and reference database, and copy your whole Tourmaline directory out of the container when the run is completed.
See the Install page for more details on installing and running Docker.
If this is your first time running Tourmaline, you'll need to set up your directory. Simplified instructions are below, but see the Wiki's Setup page for complete instructions.
Start by cloning the Tourmaline directory and files:
git clone https://github.com/aomlomics/tourmaline.git
If using the Docker container, it's recommended you run the above command from inside /data
.
The test data (16 samples of paired-end 16S rRNA data with 1000 sequences per sample) comes with your cloned copy of Tourmaline. It's fast to run and will verify that you can run the workflow.
Download reference database sequence and taxonomy files, named refseqs.qza
and reftax.qza
(QIIME 2 archives), in 01-imported
:
cd tourmaline/01-imported
wget https://data.qiime2.org/2021.2/common/silva-138-99-seqs-515-806.qza
wget https://data.qiime2.org/2021.2/common/silva-138-99-tax-515-806.qza
ln -s silva-138-99-seqs-515-806.qza refseqs.qza
ln -s silva-138-99-tax-515-806.qza reftax.qza
Edit FASTQ manifests manifest_se.csv
and manifest_pe.csv
in 00-data
so file paths match the location of your tourmaline
directory. In the command below, replace /path/to
with the location of your tourmaline
directory—or skip this step if you are using the Docker container and you cloned tourmaline
into /data
:
cd ../00-data
cat manifest_pe.csv | sed 's|/data/tourmaline|/path/to/tourmaline|' > temp && mv temp manifest_pe.csv
cat manifest_pe.csv | grep -v "reverse" > manifest_se.csv
Go to Run Snakemake.
If you're ready to run your own data, the setup is similar to what you did for the test data:
- Prepare reference database:
- Option 1: Put taxonomy and FASTA files in
00-data
. Check that filenames match those inconfig.yaml
. - Option 2: Put imported QIIME 2 archives in
01-imported
. Check that filenames match those inconfig.yaml
.
- Option 1: Put taxonomy and FASTA files in
- Prepare sequence data:
- Option 1: Edit FASTQ manifests in
00-data
so file paths point to your .fastq.gz files (they can be anywhere on your computer) and sample names match the metadata file. You can use a text editor such as Sublime Text, nano, vim, etc. Check that manifest filenames match those inconfig.yaml
. - Option 2: Put your pre-imported FASTQ .qza files in
01-imported
. Check that .qza filenames match those inconfig.yaml
.
- Option 1: Edit FASTQ manifests in
- Edit metadata file
metadata.tsv
to contain your sample names and any relevant metadata for your samples. You can use a spreadsheet editor like Microsoft Excel or LibreOffice, but make sure to export the output in tab-delimited format. - Edit configuration file
config.yaml
to change input file names (or preferably, rename your input files to match the defaults), DADA2/Deblur parameters (sequence truncation/trimming, sample pooling, chimera removal, etc.), rarefaction depth, taxonomic classification method, and other parameters. This YAML (yet another markup language) file is a regular text file that can be edited in Sublime Text, nano, vim, etc. - Go to Run Snakemake.
Shown here is the DADA2 paired-end workflow. See the Wiki's Run page for complete instructions on all steps, denoising methods, and filtering modes.
Note that any of the commands below can be run with various options, including --printshellcmds
to see the shell commands being executed and --dryrun
to display which rules would be run but not execute them. To generate a graph of the rules that will be run from any Snakemake command, see the section "Directed acyclic graph (DAG)" on the Run page.
From the tourmaline
directory (which you may rename), run Snakemake with the denoise rule as the target:
snakemake dada2_pe_denoise
Pausing after the denoise step allows you to make changes before proceeding:
- Check the table summaries and representative sequence lengths to determine if DADA2 or Deblur parameters need to be modified. If so, you can rename or delete the output directories and then rerun the denoise rule.
- View the table visualization to decide an appropriate subsampling (rarefaction) depth. Then modify the parameters "alpha_max_depth" and "core_sampling_depth" in
config.yaml
. - Decide whether to filter your feature table and representative sequences by taxonomy or feature ID. After the taxonomy step, you can examine the taxonomy summary and bar plot to aid your decision. If you do filter your data, all output from that point on will go in a separate folder so you can compare output with and without filtering.
Continue the workflow without filtering (for now). If you are satisfied with your parameters and files, run the taxonomy rule (for unfiltered data):
snakemake dada2_pe_taxonomy_unfiltered
Next, run the diversity rule (for unfiltered data):
snakemake dada2_pe_diversity_unfiltered
Finally, run the report rule (for unfiltered data):
snakemake dada2_pe_report_unfiltered
Filtering is done on representative sequences and the feature table, and downstream outputs will be filtered; the taxonomy file itself is not filtered. Filtering can be done by taxonomy keywords and/or by feature IDs of specific representative sequences. To filter by these two methods, before running taxonomy_filtered, do this:
- Taxonomy keyword: Place the keywords in
config.yaml
in the field "exclude_terms", separated by commas. Searching is not case-sensitive. - Specific representative sequences: Go to
2-output-dada2-pe-unfiltered/02-alignment-tree
and copy or mergerepseqs_to_filter_outliers.tsv
and/orrepseqs_to_filter_unassigned.tsv
to00-data/repseqs_to_filter_dada2-pe.tsv
. If merging the two files, take care to remove duplicate feature IDs, because duplicates will cause the filtering step to fail.
Now we are ready to filter the representative sequences and feature table, generate new summaries, and generate a new taxonomy bar plot, by running the taxonomy rule (for filtered data):
snakemake dada2_pe_taxonomy_filtered
Next, run the diversity rule (for filtered data):
snakemake dada2_pe_diversity_filtered
Finally, run the report rule (for filtered data):
snakemake dada2_pe_report_filtered
Open your HTML report (e.g., 03-reports/report_dada2-pe_unfiltered.html
) in Chrome{target="_blank"} or Firefox{target="_blank"}. To view the linked files:
- QZV (QIIME 2 visualization): click to download, then drag and drop in https://view.qiime2.org{target="_blank"}. Empress trees (e.g.,
rooted_tree.qzv
) may take more than 10 minutes to load. - TSV (tab-separated values): click to download, then open in Microsoft Excel or Tabview (command line tool that comes with Tourmaline).
- PDF (portable document format): click to open and view in new tab.
Downloaded files can be deleted after viewing because they are already stored in your Tourmaline directory.
- The whole workflow with test data should take ~3–5 minutes to complete. A normal dataset may take several hours to complete.
- If any of the above commands don't work, read the error messages carefully, try to figure out what went wrong, and attempt to fix the offending file. A common issue is the file paths in your FASTQ manifest file need to be updated.
- Do not use the
--cores
option. Tourmaline should be run with 1 core (default). The parameters for multiple threads in the configuration file don't do anything at this time. - If you are running in a Docker container and you get an error like "Signals.SIGKILL: 9", you probably need to give Docker more memory. See the Wiki section on Installation options.
-
The whole workflow can be run with just the command
snakemake dada2_pe_report_unfiltered
(without filtering representative sequences) orsnakemake dada2_pe_report_filtered
(after filtering representative sequences). Warning: If your parameters are not optimized, the results will be suboptimal (garbage in, garbage out). -
If you want to make a fresh run and not save the previous output, simply delete the output directories (e.g.,
02-output-{method}-{filter}
and03-report
) generated in the previous run. -
You can always delete any file you want to regenerate. Then there are several ways to regenerate it: run
snakemake FILE
and Snakemake will determine which rules (commands) need to be run to generate that file; or, runsnakemake RULE
where the rule generates the desired file as output. -
If you've run Tourmaline on your dataset before, you can speed up the setup process and initialize a new Tourmaline directory (e.g.,
tourmaline-new
) with the some of the files and symlinks of the existing one (e.g.,tourmaline-existing
) using the command below:cd /path/to/tourmaline-new scripts/initialize_dir_from_existing_tourmaline_dir.sh /path/to/tourmaline-existing
You may get error messages if some files don't exist, but it should have copied the files that were there. The files that will be copied from the existing directory to the new directory are:
config.yaml 00-data/manifest_pe.csv 00-data/manifest_se.csv 00-data/metadata.tsv 00-data/repseqs_to_filter_dada2-pe.tsv 00-data/repseqs_to_filter_dada2-se.tsv 00-data/repseqs_to_filter_deblur-se.tsv 01-imported/refseqs.qza 01-imported/reftax.qza 01-imported/classifier.qza
Ensure you make any changes to your configuration file and (if necessary) delete any files you want to be regenerated before you run Snakemake.
Some alternative pipelines for amplicon sequence analysis include the following:
- Anacapa Toolkit from UCLA: https://github.com/limey-bean/Anacapa
- Banzai from MBON: https://github.com/jimmyodonnell/banzai
- Sarah Hu's QIIME 2 Snakemake workflow: https://github.com/shu251/tagseq-qiime2-snakemake