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
)
- User-defined frame offset applied to all sequences (
- 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
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
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
Algorithm | Hash digest | |
---|---|---|
SHA256 | 280a035573dc2e709d226b628fbee41d1ee6afcff5f7a7185aac05135314a2e2 |
|
MD5 | e17e75a2acc80d84fdc91c78d9377232 |
|
BLAKE2b-256 | 36a8363012a1bf258b7d4cd562248d72c44493aa74828cdb3af1626b04e7e0d1 |
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
Algorithm | Hash digest | |
---|---|---|
SHA256 | c7685a86a5eeb0a8ef98e1853eb26015065c5ccb8dbfed6a2ea8a0b788799622 |
|
MD5 | 52f994941d44c5b007251098e639605d |
|
BLAKE2b-256 | d2a4dab3f6dee73684a8fee238c52ca0d15d6b0e967877c7d5f2e5e25c7889b1 |