Skip to main content

trim adapters from high-throughput sequencing reads

Project description

Travis CI PyPi DOI

Atropos

Atropos is tool for specific, sensitive, and speedy trimming of NGS reads. It is a fork of the venerable Cutadapt read trimmer (https://github.com/marcelm/cutadapt, DOI:10.14806/ej.17.1.200), with the primary improvements being:

  1. Multi-threading support, including an extremely fast "parallel write" mode.
  2. Implementation of a new insert alignment-based trimming algorithm for paired-end reads that is substantially more sensitive and specific than the original Cutadapt adapter alignment-based algorithm. This algorithm can also correct mismatches between the overlapping portions of the reads.
  3. Options for trimming specific types of data (miRNA, bisulfite-seq).
  4. A new command ('detect') that will detect adapter sequences and other potential contaminants.
  5. A new command ('error') that will estimate the sequencing error rate, which helps to select the appropriate adapter- and quality- trimming parameter values.
  6. A new command ('qc') that generates read statistics similar to FastQC. The trim command can also compute read statistics both before and after trimming (using the '--stats' option).
  7. Improved summary reports, including support for serialization formats (JSON, YAML, pickle), support for user-defined templates (via the optional Jinja2 dependency), and integration with MultiQC.
  8. The ability to merge overlapping reads (this is experimental and the functionality is limited).
  9. The ability to write the summary report and log messages to separate files.
  10. The ability to read SAM/BAM files and read/write interleaved FASTQ files.
  11. Direct trimming of reads from an SRA accession.
  12. A progress bar, and other minor usability enhancements.

Manual installation

Atropos is available from pypi and can be installed using pip.

First install dependencies:

  • Required
    • Python 3.4.5+ (python 2.x is NOT supported)
    • Cython 0.25.2+ (pip install Cython)
  • Maybe python libraries
    • pytest (for running unit tests)
    • progressbar2 or tqdm (progressbar support)
    • pysam (SAM/BAM input)
    • khmer 2.0+ (for detecting low-frequency adapter contamination)
    • jinja2 (for user-defined report formats)
    • ngstream (for SRA streaming), which requires ngs

Pip can be used to install atropos and optional dependencies, e.g.:

pip install atropos[tqdm,pysam,ngstream]

Conda

There is an Atropos recipe in Bioconda.

conda install -c bioconda atropos

Docker

A Docker image is available for Atropos in Docker Hub.

docker run jdidion/atropos <arguments>

Usage

Atropos is almost fully backward-compatible with cutadapt. If you currently use cutadapt, you can simply install Atropos and then substitute the executable name in your command line, with one key difference: you need to use options to specify input file names. For example:

atropos -a AGATCGGAAGAGCACACGTCTGAACTCCAGTCACGAGTTA -o trimmed.fq.gz -se reads.fq.gz

To take advantage of multi-threading, set the --threads option:

atropos --threads 8 -a AGATCGGAAGAGCACACGTCTGAACTCCAGTCACGAGTTA -o trimmed.fq.gz -se reads.fq.gz

To take advantage of the new aligner (if you have paired-end reads with 3' adapters), set the --aligner option to 'insert':

atropos --aligner insert -a AGATCGGAAGAGCACACGTCTGAACTCCAGTCACACAGTGATCTCGTATGCCGTCTTCTGCTTG \
  -A AGATCGGAAGAGCGTCGTGTAGGGAAAGAGTGTAGATCTCGGTGGTCGCCGTATCATT -o trimmed.1.fq.gz -p trimmed.2.fq.gz \
  -pe1 reads.1.fq.gz -pe2 reads.2.fq.gz

See the Documentation for more complete usage information.

Publications

Atropos is published in PeerJ.

Please cite as:

Didion JP, Martin M, Collins FS. (2017) Atropos: specific, sensitive, and speedy trimming of sequencing reads. PeerJ 5:e3720 https://doi.org/10.7717/peerj.3720

The results in the paper can be fully reproduced using the workflow defined in the paper directory.

The citation for the original Cutadapt paper is:

Marcel Martin. "Cutadapt removes adapter sequences from high-throughput sequencing reads." EMBnet.Journal, 17(1):10-12, May 2011. http://dx.doi.org/10.14806/ej.17.1.200

Links

Roadmap

1.2

  • Migrate to xphyle for file management.
  • Migrate to pokrok for progress bar management.
  • Accept multiple input files.
  • Support SAM output (including #33).
  • Direct streaming and trimming of reads from SRA and htsget using ngstream.
  • Read "cropping" (#50)
  • Support for ThruPlex-style adapters (in which barcode is part of query sequence; #55)
  • Accessibility:
    • Create recipe for homebrew.
    • Automatically update conda and homebrew recipes for each release.
    • Create Galaxy tool description using argparse2tool.
  • Improve documentation (#24)
  • Port over improvements in latest versions of Cutadapt https://cutadapt.readthedocs.io/en/stable/
  • Switch to using entry point instead of Atropos executable.

1.3

1.4

  • Currently, InsertAligner requires a single 3' adapter for each end. Adapter trimming will later be generalized so that A) the InsertAligner can handle multiple matched pairs of adapters and/or B) multiple different aligners can be used for different adapters.
  • Integrate with AdapterBase for improved matching of detected contaminants to known adapters, automated trimming of datasets with known adapters, and (opt-in) submission of adapter information for novel datasets.
  • Migrate to seqio (https://github.com/jdidion/seqio) for reading/writing sequence files.
  • General-purpose read filtering based on read ID: https://github.com/marcelm/cutadapt/issues/107.
  • Currently, SAM/BAM input files must be name sorted; add an option to 1) pre-sort reads inline using samtools or sambamba, or 2) cache each read in memory until its mate is found.

1.5

  • Provide more user control over anchoring of adapters: https://github.com/marcelm/cutadapt/issues/53.
  • Enable user to define custom read structure: https://github.com/nh13/read-structure-examples
  • Support for paired-end demultiplexing
  • Demultiplexing based on barcodes: https://github.com/marcelm/cutadapt/issues/118.
  • Consider supporting different error rates for read1 vs read2.
  • Add a ClipOverlapping modifier that will remove read overlaps (as opposed to merging).
  • Look more closely at providing solutions to the Illumina two-color chemistry issue:
    • Provide and option to exempt G calls from the assessment of quality
    • Trim 3′ Gs from reads
  • Also look at addressing any issues with one-color chemistry (iSeq).
  • Consider whether to support trimming/QC of raw IonTorrent data.

1.6

2.0

Beyond 2.0

  • Implement additional alternate alignment algorithms.
  • Implement the error detection algorithm in ADEPT: https://github.com/LANL-Bioinformatics/ADEPT
  • Explore new quality trimming algorithms
  • Scythe is an interesting new trimmer. Depending on how the benchmarks look in the forthcoming paper, we will add it to the list of tools we compare against Atropos, and perhaps implement their Bayesian approach for adapter match.
  • Experiment with replacing the multicore implementation with an asyncio-based implementation (using ProcessPoolExecutor and uvloop).
  • Automatic adaptive tuning of queue sizes to maximize the balance between memory usage and latency.
  • FastProNGS has some nice visualizations that could be included, rather than relying on MultiQC: https://github.com/Megagenomics/FastProNGS

While we consider the command-line interface to be stable, the internal code organization of Atropos is likely to change. At this time, we recommend to not directly interface with Atropos as a library (or to be prepared for your code to break). The internal code organization will be stabilized as of version 2.0, which is planned for sometime in 2017.

If you would like to suggest additional enhancements, you can submit issues and/or pull requests at our GitHub page.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

atropos-1.1.23.tar.gz (464.1 kB view details)

Uploaded Source

Built Distributions

atropos-1.1.23-py3.6-macosx-10.14-x86_64.egg (513.3 kB view details)

Uploaded Source

atropos-1.1.23-cp36-cp36m-macosx_10_14_x86_64.whl (295.1 kB view details)

Uploaded CPython 3.6m macOS 10.14+ x86-64

File details

Details for the file atropos-1.1.23.tar.gz.

File metadata

  • Download URL: atropos-1.1.23.tar.gz
  • Upload date:
  • Size: 464.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.0.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/40.6.2 requests-toolbelt/0.9.1 tqdm/4.38.0 CPython/3.6.9

File hashes

Hashes for atropos-1.1.23.tar.gz
Algorithm Hash digest
SHA256 e1a9d030fcaff21a10ca2d5a569451e52f2d6f8f6b2a34ab3574453bda46da9f
MD5 3e14d48ffb88e1b23cccb4e7323921f8
BLAKE2b-256 d260c78b463063920f7638bd54883e314448d34ee7215021f357d0bf7adae238

See more details on using hashes here.

File details

Details for the file atropos-1.1.23-py3.6-macosx-10.14-x86_64.egg.

File metadata

  • Download URL: atropos-1.1.23-py3.6-macosx-10.14-x86_64.egg
  • Upload date:
  • Size: 513.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.0.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/40.6.2 requests-toolbelt/0.9.1 tqdm/4.38.0 CPython/3.6.9

File hashes

Hashes for atropos-1.1.23-py3.6-macosx-10.14-x86_64.egg
Algorithm Hash digest
SHA256 67f47114a53a76bedf65a5f539d81b8e7021e70f83a4b103299bb88cd2d18c1f
MD5 88c246dcf062e831bf5f473e894f45a0
BLAKE2b-256 5ef1d4d9a4bcac51e602457f7b44b7dd69f9eda0f40cbfa029a8ebde73a36e80

See more details on using hashes here.

File details

Details for the file atropos-1.1.23-cp36-cp36m-macosx_10_14_x86_64.whl.

File metadata

  • Download URL: atropos-1.1.23-cp36-cp36m-macosx_10_14_x86_64.whl
  • Upload date:
  • Size: 295.1 kB
  • Tags: CPython 3.6m, macOS 10.14+ x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.0.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/40.6.2 requests-toolbelt/0.9.1 tqdm/4.38.0 CPython/3.6.9

File hashes

Hashes for atropos-1.1.23-cp36-cp36m-macosx_10_14_x86_64.whl
Algorithm Hash digest
SHA256 5f205855defcce43c9d29227749c568a7c434b5c9c30e9b033dbb9e0c5b5ec3d
MD5 b1c8ea48439130789ebc3ed0816f1c28
BLAKE2b-256 abbba6fd1c32e4ea2c6cd55e955894a549721260f41e326ad8d1a1fe6782dbde

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page