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.0.tar.gz (16.9 kB view details)

Uploaded Source

Built Distribution

pytransaln-0.2.0-py3-none-any.whl (17.0 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: pytransaln-0.2.0.tar.gz
  • Upload date:
  • Size: 16.9 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.0.tar.gz
Algorithm Hash digest
SHA256 f24216fcff87628637a939f64aad1252cfd18895ae8e1db658de90529e6342ae
MD5 ef71179d4cae312e0f6431987db8b656
BLAKE2b-256 e4b4c21ec47708e34c4af00653cd81d1836cf44b2d0e0326f576b4d51b33d980

See more details on using hashes here.

File details

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

File metadata

  • Download URL: pytransaln-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 17.0 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.0-py3-none-any.whl
Algorithm Hash digest
SHA256 172e8d4af55d2e2cb19e1d05bc841a8cd7ba6dd6b5a284c75e7e77ca8d206f25
MD5 9b0d5e164495fff1eda09cb05fa2301c
BLAKE2b-256 a3269da59184d369f8fb5ba4e0d8d58b183b7651b6e47701e24a8474536e9ead

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