Skip to main content

Translation-guided nucleotide alignment for coding sequences

Project description

Translation-guided alignment of nucleotide sequences

Several established tools for translation-guided codon alignment are no longer maintained or available for download, e.g. TranslatorX or pal2nal, or may need to be ported to new language or dependency versions to work properly, e.g. transAlign.

This package reimplements some features of the above programs to perform simple translation-guided nucleotide (codon) alignments, and to screen for pseudogenes with frameshift indels or non-sense substitutions.

The tool can be used to perform alignment or simply report sequence statistics and flag potential pseudogenes. The intended use case is to screen and align collections of PCR-amplified coding sequences used for metabarcoding, e.g. the mitochondrial cytochrome c oxidase subunit I (mtCOI) gene fragment.

How the alignment works

Reading frame can be manually specified or guessed with a heuristic. Genetic code must be manually specified; heuristic to guess genetic code is not yet implemented.

Choose reading frames for translation:

  • Reading frame can be chosen in one of three ways (specified to option --how):
    • User-defined frame offset applied to all sequences (--how user)
    • Apply same frame to all sequences, choose consensus frame that minimizes total number of stop codons across all sequences (--how cons)
    • Choose frame individually for each sequence that minimizes stop codons for that sequence; may result in ties where a sequence may have more than one 'best' reading frame (--how each)
  • Sequences that have more than the maximum allowed number of stop codons in any reading frame are flagged as putative pseudogenes.
  • The 'good' sequences are translated in the reading frame as chosen above.
  • If there is more than one reading frame with zero stop codons, the two (or three) alternative translations are each pairwise aligned to the remaining sequences with an unambiguous best reading frame. The frame that has the highest total alignment score is chosen.
  • Optional: If an HMM representing the target protein sequence is provided (option --hmm), the 'good' sequences will be screened against this HMM; sequences with outlier bit scores will not be used for the initial aligment
  • Translated 'good' sequences are aligned with MAFFT; nucleotide sequences are then aligned as codons using this amino acid alignment

Dealing with pseudogenes/frameshifted sequences (adapted from transAlign, see Bininda-Edmonds, 2005):

  • Nucleotide sequences of putative pseudogenes are then aligned against the reference 'good' alignment with MAFFT --add option
  • Likely frameshift positions in putative pseudogenes are reported from the positional map of the reference-guided alignment

Assumptions

  • Input sequences are homologous
  • Input sequences are protein coding sequences without introns or untranslated regions
  • Input sequences are long enough that wrong reading frame will be evident in excessive stop codons (warning if average sequence length is under 50)
  • If pseudogenes are present, majority of sequences are not pseudogenes (warning if more than half of sequences have excessive stop codons)
  • Sequences all use the same genetic code

For a more careful alignment, or for sequence sets with many frameshifted sequences, use MACSE instead, however MACSE is quite slow for de novo alignments and is probably overkill for most "normal" datasets where most sequences do not have frameshifts.

Installation

Install from PyPI with pip, preferably into a virtualenv or Conda environment:

pip install pytransaln

External dependencies are not installed via pip, but should also be in path:

  • MAFFT >=6.811; tested with v7.520.

Usage

See help message for details

pytransaln --help

It is recommended to inspect the alignment afterwards or apply quality checks with other programs such as trimAl.

To view alignments on the command line you can use alv and pipe to less with the -R option:

alv -t codon -l alignment.fasta | less -R

Output alignment

Note that:

  • Leading and trailing bases not contained in complete codons may be omitted
  • Portions of the putative pseudogene sequences that were aligned in the second step to the initial 'good' alignment may be omitted from the final 'augmented' alignment to preserve the reading frame. See the frameshift report file for details.

Testing and benchmarking

Commands to run tests with example data (from the benchmark data sets distributed with transAlign) are in the Makefile:

make help # list available commands
make benchmark # download test data and run alignments
make clean # delete benchmark output

Future enhancements

In order of priority

  • Add pre and post frame sequence back to alignment
  • Guess genetic code
  • Translate 6 frames
  • User-supplied input amino acid alignment

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

pytransaln-0.2.1.tar.gz (17.7 kB view details)

Uploaded Source

Built Distribution

pytransaln-0.2.1-py3-none-any.whl (17.7 kB view details)

Uploaded Python 3

File details

Details for the file pytransaln-0.2.1.tar.gz.

File metadata

  • Download URL: pytransaln-0.2.1.tar.gz
  • Upload date:
  • Size: 17.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.6

File hashes

Hashes for pytransaln-0.2.1.tar.gz
Algorithm Hash digest
SHA256 280a035573dc2e709d226b628fbee41d1ee6afcff5f7a7185aac05135314a2e2
MD5 e17e75a2acc80d84fdc91c78d9377232
BLAKE2b-256 36a8363012a1bf258b7d4cd562248d72c44493aa74828cdb3af1626b04e7e0d1

See more details on using hashes here.

File details

Details for the file pytransaln-0.2.1-py3-none-any.whl.

File metadata

  • Download URL: pytransaln-0.2.1-py3-none-any.whl
  • Upload date:
  • Size: 17.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.6

File hashes

Hashes for pytransaln-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 c7685a86a5eeb0a8ef98e1853eb26015065c5ccb8dbfed6a2ea8a0b788799622
MD5 52f994941d44c5b007251098e639605d
BLAKE2b-256 d2a4dab3f6dee73684a8fee238c52ca0d15d6b0e967877c7d5f2e5e25c7889b1

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