Skip to main content

A tool for handling repetitive insertions into sequence alignments

Project description

brawn

A python port of MUSCLE's profile-profile mode for aligning sequences.

Brawn was specifically designed with repetitive insertions of query sequences into reference alignments in mind.

Brawn takes advantage of that repetitive nature by using cache files to remove the calculations that would need to be repeated over and over for the reference alignments. This counters the speed loss of moving from C to python. Initially building these cache files will take about 10 times longer than an equivalent single run.

While results are often identical to those from MUSCLE, there will occasionally be some minor variations. If an alignment would be very poor in the best case, this variation will be more pronounced.

Only protein sequences are explicitly supported at the moment, full DNA/RNA support may follow later.

Installation

from PyPI

pip install brawn

from source

pip install .

for development

pip install .[testing]

Use

For speed, using a cache file is extremely important. They can be built and used both programatically and the command line. They are also optional, if required.

Basic profile-profile mode

To load an alignment from a FASTA file, use:

from brawn import Alignment

with open("some.fasta") as handle:
    alignment = Alignment.from_file(handle)

Or, to build from an existing dictionary (even if it's just one element), use:

name_to_sequence = {
    "A": "GT-DVG",
    "B": "GTK-VG",
}
alignment = Alignment(name_to_sequence)

Or, to load cached calculations directly (this is the preferable option for large alignments):

with open("reference.cache") as handle:
    alignment = Alignment.from_cache_file(handle)

As a sidenote, to build a cache for the reference alignment:

with open("reference.cache", "w") as handle:
    alignment.to_cache_file(handle)

This will add any needed computational steps prior to writing.

Once two alignments have been created/loaded, they can be combined with:

from brawn import combine_alignments

result = combine_alignments(alignment1, alignment2)

And the resulting alignment can be output to file:

with open("output.fasta", "w") as handle:
    result.to_file(handle=handle)

# if handle is not supplied, the output will be sent to sys.stdout
results.to_file()

Simpler insertion of a sequence into an alignment

For the use case that brawn was designed for, only a single sequence is being inserted into a reference alignment at a time. This is usually paired with fetching a single reference sequence, and finding the matching sites.

# note: this still aligns with the full reference alignment
# only the reference sequence mentioned by name will be built
aligned_query, aligned_reference = get_aligned_pair(query_sequence, reference_name,
                                                    reference_alignment)

Or, if you prefer to have the full set of newly aligned reference sequences as a dictionary:

aligned_query, aligned_refs_by_name = insert_into_alignment(query_sequence, alignment)

From the command line

Brawn can function as a drop-in replacement for MUSCLE's -profile mode, complete command line argument conversion.

To take advantage of cached alignment calculations, first build a cache of your alignment, with:

brawn input.fasta --build-cache desired_cache_path

From that point, you can use cached files and plain FASTA files interchangeably. E.g.

brawn query.fasta --reference-alignment some_fasta_file

and

brawn query.fasta --reference-alignment some_cache_file

will both work as expected.

For the command line, the resulting FASTA output will to be stdout.

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

brawn-1.0.1.tar.gz (38.4 kB view details)

Uploaded Source

Built Distribution

brawn-1.0.1-py3-none-any.whl (41.7 kB view details)

Uploaded Python 3

File details

Details for the file brawn-1.0.1.tar.gz.

File metadata

  • Download URL: brawn-1.0.1.tar.gz
  • Upload date:
  • Size: 38.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.0

File hashes

Hashes for brawn-1.0.1.tar.gz
Algorithm Hash digest
SHA256 dd76831a9dee955692082f46209db645bceb2e48509cbe0eeb9d9e20f53cbb6c
MD5 4b1730a04941bb69a9ca7668ef799e8c
BLAKE2b-256 1a7dabd734ec8b452d87f501cb57da1cb55f4ab999e5fe2d570c1f51374c70b5

See more details on using hashes here.

File details

Details for the file brawn-1.0.1-py3-none-any.whl.

File metadata

  • Download URL: brawn-1.0.1-py3-none-any.whl
  • Upload date:
  • Size: 41.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.2

File hashes

Hashes for brawn-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 917f56f87bc91b72bb2dd663276bf85fd139ee56a3676a2bef5a7fb0d29e2bbf
MD5 f43e6528b9d4015b895707c77127cb7d
BLAKE2b-256 ca1d5f95451df8ce8a88ffb610457012a5ab1a5e620df446f3d6556a7c75a26d

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